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METHOD, SYSTEM AND 
COMPUTER SOFTWARE FOR 
ONLINE ORDERING OF CUSTOM 

PROBE ARRAYS 

Cross Reference To Related Applications 

The present application claims priority from U.S. Provisional Patent Applications Serial 
Nos. 60/265,103, entitled "RAPID FLEXIBLE CONTENT ARRAY AND ONLINE ORDERING 
SYSTEM", filed January 29, 2001; 60/301,298, entitled "WEB APPLICATION FOR 
DESIGNING AND ORDERING FLEXIBLE CONTENT ARRAYS", filed June 25, 2001; 
60/306,033, entitled "PROBESET ANNOTATIONS," filed July 16, 2001; 60/333,522, 
entitled "METHOD, SYSTEM, AND COMPUTER SOFTWARE FOR PROVIDING A GENOMIC 
WEB PORTAL," filed November 27, 2001; 60/343,51 1, entitled "METHOD, SYSTEM, 
AND COMPUTER SOFTWARE FOR PROVIDING A GENOMIC WEB PORTAL," filed December 
21 , 2001 ; 60/349,546, entitled "METHOD, SYSTEM, AND COMPUTER SOFTWARE FOR 
PROVIDING A GENOMIC WEB PORTAL", filed January 1 8, 2002; 60/375,875, titled 
"VISUALIZATION SOFTWARE FOR DISPLAYING GENOMIC SEQUENCE AND 
ANNOTATIONS", filed April 25, 2002; 60/376,003, entitled "METHOD, SYSTEM, AND 
COMPUTER SOFTWARE FOR PROVIDING A GENOMIC WEB PORTAL", filed April 26, 2002; 
60/394,574, entitled "METHOD, SYSTEM, AND COMPUTER SOFTWARE FOR PROVIDING 
A GENOMIC WEB PORTAL", filed July 9, 2002; and 60/403,381 , entitled "METHOD, 
SYSTEM, AND COMPUTER SOFTWARE FOR PROVIDING A GENOMIC WEB PORTAL", filed 
August 14, 2002, all of which are hereby incorporated herein by reference in their 
entireties for all purposes. The present application is also a continuation in part of, 
and claims priority from, U.S. Patent Application Serial No. 10/063,559, titled 
"METHOD, SYSTEM, AND COMPUTER SOFTWARE FOR PROVIDING A GENOMIC WEB 
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PORTAL", filed May 2, 2002; and Patent Cooperation Treaty Patent Application Serial 
No. PCT/US 02/1 3902, titled "METHOD, SYSTEM, AND COMPUTER SOFTWARE FOR 
PROVIDING A GENOMIC WEB PORTAL", filed May 2, 2002. The present application is 
related to U.S. Patent Application No. 10/065,856, entitled "METHOD, SYSTEM, AND 
COMPUTER SOFTWARE FOR VARIANT INFORMATION VIA A WEB PORTAL, "filed 
concurrently herewith and incorporated herein by reference in its entirety for all 
purposes. 

Background of Invention 

[0001] Field of the Invention: The present invention relates to the field of bioinformatics. 
In particular, the present invention relates to computer systems, methods, and 
products for providing genomic information and products over networks such as the 
Internet. 

[0002] Related Art: Research in molecular biology, biochemistry, and many related health 
fields increasingly requires organization and analysis of complex data generated by 
new experimental techniques. These tasks are addressed by the rapidly evolving field 
of bioinformatics. See, e.g., H. Rashidi and K. Buehler, Bioinformatics Basics: 
Applications in Biological Science and Medicine (CRC Press, London, 2000); 
Bioinformatics: Practical Guide to the Analysis of Gene and Proteins (B.F. Ouelette and 
A.D. Baxevanis, eds., Wiley & Sons, Inc.; 2d ed., 2001), both of which are hereby 
incorporated herein by reference in their entireties. Broadly, one area of 
bioinformatics applies computational techniques to large genomic databases, often 
distributed over and accessed through networks such as the Internet, for the purpose 
of illuminating relationships among gene structure and/or location, protein function, 
and metabolic processes. 

Summary of Invention 

[0003] The expanding use of microarray technology is one of the forces driving the 
development of bioinformatics. In particular, microarrays and associated 
instrumentation and computer systems have been developed for rapid and large-scale 
collection of data about the expression of genes or expressed sequence tags (ESTs) in 
tissue samples. The data may be used, among other things, to study genetic 
characteristics and to detect mutations relevant to genetic and other diseases or 



App_lD=10065868 Page 2 of 109 



:i . il O «t. f 3 4, r i, „, ; J . . a p ^; IS o f ; 



conditions. More specifically, the data gained through microarray experiments is 
valuable to researchers because, among other reasons, many disease states can 
potentially be characterized by differences in the expression levels of various genes, 
either through changes in the copy number of the genetic DNA or through changes in 
levels of transcription (e.g., through control of initiation, provision of RNA precursors, 
or RNA processing) of particular genes. Thus, for example, researchers use 
microarrays to answer questions such as: Which genes are expressed in cells of a 
malignant tumor but not expressed in either healthy tissue or tissue treated according 
to a particular regime? Which genes or EST's are expressed in particular organs but 
not in others? Which genes or EST's are expressed in particular species but not in 
others? How does the environment, drugs, or other factors influence gene expression? 
Data collection is only an initial step, however, in answering these and other 
questions. Researchers are increasingly challenged to extract biologically meaningful 
information from the vast amounts of data generated by microarray technologies, and 
to design follow-on experiments. A need exists to provide researchers with improved 
tools and information to perform these tasks. 

[0004] Systems, methods, and computer program products are described herein to 
address these and other needs. In some embodiments, a web portal processes 
inquiries regarding biological information, biological devices or substances, reagents, 
and other information or products related to results of microarray experiments. In 
some implementations, the user selects "probe-set identifiers" (a broad term that is 
described below) that may be associated with probe sets of one or more probes. 
These probe sets are capable of enabling detection of biological molecules. These 
biological molecules include, but are not limited to, nucleic acids including DNA 
representations or mRNA transcripts and/or representations of corresponding genes 
(such nucleic acids may hereafter, for convenience, be referred to simply as "mRNA 
transcripts"). The corresponding genes or EST's are identified and are correlated with 
related data and/or products, which are provided to the user. 

A genomic portal system is described that receives user-selected identifiers of 
potential probes. The system determines verified probes corresponding to the 
identifiers and generates a custom probe array design. The system then displays the 
custom probe array design the user via a graphical user interface and receives a user 



[0005] 



App_ID= 10065868 



Page 3 of 109 



:l ii o A i G l B fa B - i -Ji i^aPn jrji? 

selection specifying acceptance, modification, or rejection of the design. The system 
provides the user with the accepted or modified custom probe array. The system may 
also enable a number of users to share space on a custom probe array. Another 
optional feature is to enable a number of users to share in ordering portions of a lot 
of catalog probe arrays to take advantage of economies of scale from lot-size 
purchases. 

[0006] In accordance with a particular embodiment, a method is described for providing 
information about biological molecules. The method includes receiving a user 
selection of one or more probe set identifiers that identify one or more potential 
probes. Also included in the method are the acts of determining verified probe sets of 
verified probes corresponding to the probe set identifier and generating a custom 
probe array design based upon the verified probe set. Also included in the method is 
the act of providing to the user one or more probe arrays based on the probe array 
design, where at least one of the probe arrays is constructed and arranged to detect 
and/or measure any one or any combination of gene expression, genotype, SNP, 
haplotype, or targets including antibodies, cell membrane receptors, monoclonal 
antibodies and antisera reactive with specific antigenic determinants, drugs, 
oligonucleotides, nucleic acids, peptides, proteins, cofactors, lectins, sugars, 
polysaccharides, cells, cellular membranes, and/or organelles. The probe arrays may 
be constructed and arranged to diagnose a disease and/or medical condition, or for 
use in conducting research. Non-limiting examples of probe arrays constructed and 
arranged to diagnose a disease include probe arrays aimed at any one or more of the 
following applications: predisposition for disease or condition; screening; diagnosis; 
prognosis; pharmacogenomic applications (e.g., drug therapy selection and/or 
optimization), therapy selection and/or optimization for non-drug or combined 
therapies; monitoring of treatment response; and/or monitoring of disease 
progression, remission, and other indicators. 

[0007] tn accordance with another embodiment, a method is described that includes the 
acts of receiving a user selection of one or more probe set identifiers that identify one 
or more potential probes; determining verified probe sets of verified probes 
corresponding to the probe set identifiers; generating a custom probe array design 
based, at least in part, upon the verified probe sets; enabling for display to the user a 
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representation of one or more aspects of the custom probe array design via a 
graphical user interface enabled to receive a user selection specifying acceptance, 
modification, or rejection of the custom probe array design; and providing to the user 
one or more probe arrays based on the probe array design responsive to the user 
selection specifying acceptance or modification. The method may also include 
receiving from the user, such as over the Internet, a selection of probe set identifiers 
that may comprise sequence information. 

[0008] The probe set identifiers may be selected by the user from a predetermined list, 
where each item on the list may correspond to either an EST, a gene, a splice variant 
of a gene, or a protein. In some implementations, the verified probe sets may be 
determined based on any combination of frequency, length, and/or position of probe 
sequence repeats; probe sequence length, thermodynamic properties, energetic 
parameters, and/or uniqueness; and/or one or more characteristics of target 
molecules specified by the user for use with the probe array. Also in some 
implementations, the act of generating may further be based on probe array format 
factors where the user may provide some or all of the probe array format factors, 
where the act of receiving may further include receiving user-selected probe array 
format factor. The probe array format factors may include any one or any combination 
of the number of probe sets; a shape and/or one or more dimensions of a probe; one 
or more dimensions of active and/or inactive areas of the probe array; one or more 
indicators of geographic dispersion of probe sets on the probe array; nominal, 
maximum and/or minimum number of probes and/or probes in a probe set 
representing one or more EST, gene, splice variant of a gene, or protein; substrate 
material or design; and/or design of a hybridization chamber or microfluidics body 
encompassing and/or associated with the probe array. The substrate material may 
include one or more of glass, silicon, silica, optical fibers, beads, resins, gels, and/or 
microspheres. 

[0009] Additionally, some implementations may include the act of generating further 

includes modifying or rejecting one or more user-selected probe array format factors. 
In various implementations prior to the act of providing, enabling for display to the 
user a representation of one or more aspects of the custom probe array design via a 
graphical user interface enabled to receive a user selection specifying acceptance, 
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modification, or rejection of the custom probe array design. Also, in some 
implementations the act of determining further includes modifying or rejecting user- 
selected probe set identifiers and the act of enabling for display includes enabling a 
representation of factors or reasons related to modifying or rejecting the user- 
selected probe set identifiers. Additionally, the probe arrays include synthesized or 
spotted probe arrays. 

[001 0] In accordance with another embodiment a system is described that includes an 
input manager that receives a user selection of probe set identifiers that identify 
potential probes. The system also includes a gene or EST verifier that determines 
verified probe sets of verified probes that corresponding to the probe set identifiers. 
Additionally, the system includes a probe array that generates a custom probe array 
design based upon the verified probe sets. The system also includes a user data 
processor that provides the user at least one probe array based on the probe array 
design. 

[0011] In some implementations, the verified probe sets may be determined based on 
any combination of frequency, length, and/or position of probe sequence repeats; 
probe sequence length, thermodynamic properties, energetic parameters, and/or 
uniqueness; and/or one or more characteristics of target molecules specified by the 
user for use with the probe array. Also, some implementations the probe array 
generator may further generate the custom probe array design based, at least in part, 
on probe array format factors that may include any combination of the number of 
probe sets; a shape and/or one or more dimensions of a probe; one or more 
dimensions of active and/or inactive areas of the probe array; one or more indicators 
of geographic dispersion of probe sets on the probe array; nominal, maximum and/or 
minimum number of probes and/or probes in a probe set representing one or more 
EST, gene, splice variant of a gene, or protein; substrate material or design; and/or 
design of a hybridization chamber or microfluidics body encompassing and/or 
associated with the probe array. , 

[0012] 

A genomic portal system is described in accordance with another embodiment 
that includes an application server comprising an input manager that receives a user 
selection of at least one probe set identifier that identifies at least one potential 
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probe; a gene or EST verifier that determines at least one verified probe set of verified 
probes corresponding to the probe set identifiers; a probe array generator that 
generates a custom probe array design based, upon the verified probe sets; and a 
user data processor that enables for display, a representation of at least aspect of the 
custom probe array design via a graphical user interface that is further enabled to 
receive a user selection specifying acceptance, modification, or rejection of the 
custom probe array design. The system also includes a network server comprising an 
output manager that provides the user at least one probe array based on the probe 
array design. 

[001 3] In some implementations, the network server further comprises an input manager 
that receives user input and at least one user computers that enables a user to 
provide the user selection of one or more probe set identifiers to the network server. 
Additionally, the output manager identifies at least one probe array to the user via the 
internet. 

[0014] In accordance with another embodiment, a method is described that includes the 
acts of receiving a user selection of probe arrays, or probe set identifiers 
corresponding to probe arrays, that includes a particular type of probe array; receiving 
an order for a number probe arrays of the particular type; comparing the number of 
probe arrays ordered to a nominal lot size and to a number of unfulfilled orders that 
corresponds to the type of probe array; adding the number of probe arrays ordered to 
the unfulfilled number of orders to generate a total number of orders; and providing 
the user with the ordered number of probe arrays of the particular type when the total 
number is within a production-lot range. In some implementations, the production- 
lot range may be equal to the nominal lot size that may be predetermined and/or 
adjustable, and the order may include a conditional offer to purchase that may be 
contingent on price and/or projected delivery time. 

[001 5] Also, some implementations may further include the act of receiving a bid for a 

price that a user may be willing to pay. Additionally, the selection of probe arrays may 
be received over the Internet, and the probe set identifiers may include sequence 
information selected by the user from a predetermined list. Each item on the list may 
correspond to either an EST, a gene, a splice variant of a gene, or a protein. 
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[001 6] In accordance with another embodiment, a method is described that includes that 
acts of receiving a user selection of probe set identifiers that identify potential probes; 
determining a number of verified probe sets corresponding to the user selected probe 
set identifiers; comparing the number of verified probe sets to a nominal custom 
probe set size and to a number of unfulfilled orders for probe sets; adding the 
number of verified probe sets to the number of unfulfilled orders to generate a total 
number; and providing the user with the verified probe sets on a shared custom probe 
array when the total number is within a production range of probe sets. In some 
implementations, the production range may be limited to a value that is equal to the 
nominal custom probe set size. Additionally some implementations further comprise 
the act of receiving a bid from the user for a price that the user is willing to pay. 

[001 7] In accordance with yet another embodiment, a system is described that includes 
an input manager that receives a user selection of probe arrays, or probe set 
identifiers that correspond to probe arrays, that includes a particular type of probe 
array. The input manager may further receive an order for a number of probe arrays of 
the particular type. The system also includes a user-service manager that compares 
the ordered number of particular type of probe arrays to a nominal lot size 
corresponding to the particular type of probe arrays and to a number of unfulfilled 
orders; adds the ordered number to the unfulfilled orders to generate a total number; 
and provides the user with the ordered number of probe arrays of the particular type 
of probe array when the total is within a production-lot range. In some 
implementations the system also includes a production system that produces the 
ordered number of probe arrays, and a delivery system that provides the user with the 
ordered number of probe arrays when enabled by the user-service manager. 

[001 8] Additionally, in some implementations the input manager receives a bid from the 
user for a price that the user is willing to pay. 

[0019] 

In accordance with another embodiment, a system is described that includes for 
an input manager that receives a user selection probe set identifiers that identify 
potential probes. The system also includes a user-service manager that determines a 
number of verified probe sets corresponding to the probe set identifiers, and 
compares the number of verified probe sets to a nominal custom probe set size and 
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to a number of unfulfilled orders for probe sets. The user-service manager also adds 
the number of verified probe sets to the unfulfilled orders to generate a total number, 
and provides the number of verified probe sets on a shared custom probe array when 
the total is within a production range of probe sets. 

[0020] In yet another embodiment, a method is described for providing custom probe 
arrays, comprising the acts of: receiving a user selection of one or more probe set 
identifiers that each identify a plurality of potential probes; determining verified probe 
sets of verified probes corresponding to the probe set identifiers; generating a custom 
probe array design based, at least in part, upon the verified probe sets; and providing 
to the user one or more probe arrays based on the probe array design. 

[0021] The above implementations are not necessarily inclusive or exclusive of each other 
and may be combined in any manner that is non-conflicting and otherwise possible, 
whether they be presented in association with a same, or a different, aspect or 
implementation. The description of one implementation is not intended to be limiting 
with respect to other implementations. Also, any one or more function, step, 
operation, or technique described elsewhere in this specification may, in alternative 
implementations, be combined with any one or more function, step, operation, or 
technique described in the summary. Thus, the above implementations are illustrative 
rather than limiting. 

Brief Description of Drawings 

[0022] above and further advantages will be more clearly appreciated from the 

following detailed description when taken in conjunction with the accompanying 
drawings. In the drawings, like reference numerals indicate like structures or method 
steps and the leftmost one or two digits of a reference numeral indicate the number 
of the figure in which the referenced element first appears (for example, the element 
1 80 appears first in Figure 1 ; element 1110 appears first in Figure 1 1 ). In functional 
block diagrams, rectangles generally indicate functional elements, parallelograms 
generally indicate data, rectangles with curved sides generally indicate stored data, 
rectangles with a pair of double borders generally indicate predefined functional 
elements, and keystone shapes generally indicate manual operations. In method flow 
charts, rectangles generally indicate method steps and diamond shapes generally 



AppJD=10065868 Page 9 of 109 



X O Chi" « ifiT'l. „ 



:1 ;SL £"!!jfi,f jr* 



indicate decision elements. All of these conventions, however, are intended to be 
typical or illustrative, rather than limiting. 

[0023] Figure 1 is a functional block diagram of one embodiment of a probe-array 

analysis system including an illustrative scanner and an illustrative computer system; 

[0024] Figure 2 is a functional block diagram of one embodiment of probe-array analysis 
applications as illustratively stored for execution in system memory of the computer 
system of Figure 1 ; 

[0025] Figure 3 is a functional block diagram of a conventional system for obtaining 
genomic information over the Internet; 

[0026] Figure 4 is a functional block diagram of one embodiment of a genomic portal 

coupled over the Internet to remote databases and web pages and to clients including 
networks having user computer systems including that of Figure 1 ; 

[0027] Figure 5 is a functional block diagram of one embodiment of the genomic portal 
of Figure 4 including illustrative embodiments of a database server, portal application 
computer system, and portal-side Internet server; 

[0028] Figure 6 is a simplified graphical representation of one embodiment of computer 
application platforms for implementing the genomic portal of Figures 4 and 5 in 
communication with clients such as those shown in Figure 4; 

[0029] Figure 7A is a flow chart of one embodiment of a method for providing a user with 
web pages displaying genomic data and/or genomic product information related, for 
example, to gene expression, alternative splice variants, differential expression, 
experimental results, and/or custom probe arrays; 

[0030] Figure 7B is a flow chart of one embodiment of a method for receiving and 

processing a user selection of probe set identifiers to generate custom design probe 
arrays and/or custom design probe sets; 

[003 1 ] Figure 8 is a functional block diagram of one embodiment of a user-service 

manager application as may be executed on the portal application computer system of 
Figure 5; 
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[0032] Figure 9 is a simplified graphical representation of one embodiment of a gene or 
probe-set identifier to products and/or genomics database such as may be by the 
user-service manager of Figure 8; 

[0033] Figure 1 0 is a simplified graphical representation of one embodiment of a local 

genomic and/or product database such as may be accessed by the database server of 
Figure 5; 

[0034] Figure 1 1 is a functional block diagram of one embodiment of a gene or EST 

determiner such as may be included in the user-service manager application of Figure 

8; 

[003 5] Figure 1 2 is a functional block diagram of one embodiment of a correlator such as 
may be included in the user-service manager application of Figure 8; 

[0036] Figure 1 3A is a graphical representation of one embodiment of a graphical user 
interface suitable for providing alternative splice variant data to a user based on data 
correlated by the correlator of Figure 12; 

[0037] Figure 1 3B is a graphical representation of one embodiment of a graphical user 
interface suitable for providing alternative splice variant data to a user based on data 
correlated by the correlator of Figure 1 2; 

[0038] Figure 1 4 is a graphical representation of one embodiment of a graphical user 

interface suitable for providing options and receiving one or more user custom array 
design and/or custom probe set design selections processed by the gene or EST 
correlator of Figure 1 1 ; and 

[0039] Figure 1 5 is a graphical representation of one embodiment of a graphical user 
interface suitable for providing one or more custom probe array designs and/or 
custom probe set designs. 

Detailed Description 

[0040] 

The present invention has many preferred embodiments that, in some instances, 
may include material incorporated from patents, applications and other references for 
details known to those of the art. When a patent or patent application is referred to 
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below, it should be understood that it is incorporated by reference in its entirety for 
all purposes. 

[0041] As used in this application, the singular form "a," "an," and "the" include plural 
references unless the context clearly dictates otherwise. For example, the term "an 
agent" includes a plurality of agents, including mixtures thereof. An individual is not 
limited to a human being but may also be other organisms including but not limited 
to mammals, plants, bacteria, or cells derived from any of the above. 

[0042] Throughout this disclosure, various aspects of this invention may be presented in 
a range format. It should be understood that the description in range format is merely 
for convenience and brevity and should not be construed as an inflexible limitation on 
the scope of the invention. Accordingly, the description of a range should be 
considered to have specifically disclosed all the possible sub-ranges as well as 
individual numerical values within that range. For example, description of a range 
such as from 1 to 6 should be considered to have specifically disclosed sub-ranges 
such as from 1 to 3, from 1 to 4, from 1 to 5, from 2 to 4, from 2 to 6, from 3 to 6 
etc., as well as individual numbers within that range, for example, 1 , 2, 3, 4, 5, and 6. 
This principle applies regardless of the breadth of the range. 

[0043] 

The practice of the present invention may employ, unless otherwise indicated, 
conventional techniques and descriptions of organic chemistry, polymer technology, 
molecular biology (including recombinant techniques), cell biology, biochemistry, and 
immunology, which are within the skill of the art. Such conventional techniques 
include polymer array synthesis, hybridization, ligation, and detection of hybridization 
using a label. Specific illustrations of suitable techniques may be had by reference to 
the examples herein. However, other equivalent conventional procedures may, of 
course, also be used. Such conventional techniques and descriptions may be found in 
standard laboratory manuals such as Genome Analysis: A Laboratory Manual Series 
(Vols. I-IV), Using Antibodies: A Laboratory Manual, Cells: A Laboratory Manual, PCR 
Primer: A Laboratory Manual, and Molecular Cloning: A Laboratory Manual (all from 
Cold Spring Harbor Laboratory Press), Stryer, L. (1995) Biochemistry (4th Ed.) Freeman, 
New York, Gait, "Oligonucleotide Synthesis: A Practical Approach" 1984, IRL Press, 

rd 

London, Nelson and Cox (2000), Lehninger, Principles of Biochemistry 3 Ed., W.H. 
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Freeman Pub., New York, NY and Berg et a!. (2002) Biochemistry, 5 th Ed., W.H. 
Freeman Pub., New York, NY, all of which are herein incorporated in their entirety by 

reference for all purposes. 

[0044] The practice of the present invention may also employ conventional biology 
methods, software, and systems. Computer software products of the invention 
typically include computer readable medium having computer-executable instructions 
for performing the logic steps of the method of the invention. Suitable computer 
readable medium include floppy disk, CD-ROM/DVD/DVD-ROM, hard-disk drive, 
flash memory, ROM/RAM, magnetic tapes, and other known devices or media and 
those that may be developed in the future.. The computer executable instructions may 
be written in a suitable computer language or combination of several languages. Basic 
computational biology methods are described in, e.g. Setubal and Meidanis et al., 
Introduction to Computational Biology Methods (PWS Publishing Company, Boston, 
1997); Salzberg, Searles, Kasif, (Ed.), Computational Methods in Molecular Biology, 
(Elsevier, Amsterdam, 1998); Rashidi and Buehler, Bioinformatics Basics: Application in 
Biological Science and Medicine (CRC Press, London, 2000) and Ouelette and 
Baxevanis Bioinformatics: A Practical Guide for Analysis of Gene and Proteins (Wiley & 
nd 

Sons, Inc., 2 ed., 2001). 

[0045] As will be appreciated by one of skill in the art, the present invention may be 

embodied as a method, data processing system or program products. Accordingly, the 
present invention may take the form of data analysis systems, methods, analysis 
software, and so on. Software written according to the present invention typically is to 
be stored in some form of computer readable medium, such as memory, or CD-ROM, 
or transmitted over a network, and executed by a processor. For a description of basic 
computer systems and computer networks, see, e.g., Introduction to Computing 
Systems: From Bits and Gates to C and Beyond by Yale N. Patt, SanjayJ. Patel, 1st 
edition (January 1 5, 2000) McCraw Hill Text; ISBN: 0072376902; and Introduction to 
Client/Server Systems : A Practical Guide for Systems Professionals by Paul E. Renaud, 
2nd edition (June 1 996), John Wiley & Sons; ISBN: 0471133337, both of which are 
hereby incorporated by reference for all purposes. 

[0046] 

Computer software products may be written in any of various suitable 
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programming languages, such as C, C+ + , Fortran and Java (Sun Microsystems). The 
computer software product may be an independent application with data input and 
data display modules. Alternatively, the computer software products may be classes 
that may be instantiated as distributed objects. The computer software products may 
also be component software such as Java Beans (Sun Microsystems), Enterprise Java 
Beans (EJB), Microsoft • COM/DCOM, etc. 

[0047] Systems, methods, and computer products are now described with reference to an 
illustrative embodiment referred to as genomic portal 400. Portal 400 is shown in an 
Internet environment in Figure 4, and is illustrated in greater detail in Figures 5 
through 1 5. In a typical implementation, portal 400 may be used to provide a user 
with information related to results from experiments with probe arrays. The 
experiments often involve the use of scanning equipment to detect hybridization of 
probe-target pairs, and the analysis of detected hybridization by various software 
applications, as now described in relation to Figures 1 and 2. 

[0048] Probe Arrays 1 03: Various techniques and technologies may be used for 

synthesizing dense arrays of biological materials on or in a substrate or support. For 
example, Affymetrix CeneChip • arrays are synthesized in accordance with techniques 
sometimes referred to as VLSIPS ™ (Very Large Scale Immobilized Polymer Synthesis) 
technologies. Some aspects of VLSIPS ™ and other microarray and polymer (including 
protein) array manufacturing methods and techniques have been described in U.S.S.N 
09/536,841, WO 00/58516, U.S. Patents Nos. 5,143,854, 5,242,974, 5,252,743, 
5,324,633, 5,445,934, 5,744,305, 5,384,261, 5,405,783, 5,424,186, 5,451,683, 
5,482,867, 5,491,074, 5,527,681 , 5,550,2 1 5, 5,571,639, 5,578,832, 5,593,839, 
5,599,695, 5,624,71 1, 5,631,734, 5,795,716, 5,831,070, 5,837,832, 5,856,101, 
5,858,659, 5,936,324, 5,968,740, 5,974,164, 5,981,185, 5,981,956, 6,025,601, 
6,033,860, 6,040,193, 6,090,555, 6,136,269, 6,269,846, 6,022,963, 6,083,697, 
6,291,183, 6,309,831 and 6,428,752, in PCT Applications Nos. PCT/US99/00730 
(International Publication Number WO 99/36760) and PCT/US01 /04285, which are all 
incorporated herein by reference in their entireties for all purposes. 

[0049] 

Patents that describe synthesis techniques in specific embodiments include U.S. 
Patents Nos. 5,412,087, 6,147,205, 6,262,216, 6,310,189, 5,889,165, and 
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5,959,098, hereby Incorporated by reference in their entireties for all purposes. 
Nucleic acid arrays are described in many of the above patents, but the same 
techniques may be applied to polypeptide arrays. 

[0050] Generally speaking, an "array" typically includes a collection of molecules that can 
be prepared either synthetically or biosynthetically. The molecules in the array may be 
identical, they may be duplicative, and/or they may be different from each other. The 
array may assume a variety of formats, e.g., libraries of soluble molecules; libraries of 
compounds tethered to resin beads, silica chips, or other solid supports; and other 
formats. 

[0051] The terms "solid support," "support," and "substrate" may in some contexts be 

used interchangeably and may refer to a material or group of materials having a rigid 
or semi-rigid surface or surfaces. In many embodiments, at least one surface of the 
solid support will be substantially flat, although in some embodiments it may be 
desirable to physically separate synthesis regions for different compounds with, for 
example, wells, raised regions, pins, etched trenches, or other separation members or 
elements. In some embodiments, the solid support(s) may take the form of beads, 
resins, gels, microspheres, or other materials and/or geometric configurations. 

[0052] Generally speaking, a "probe" typically is a molecule that can be recognized by a 
particular target. To ensure proper interpretation of the term "probe" as used herein, 
it is noted that contradictory conventions exist in the relevant literature. The word 
"probe" is used in some contexts to refer not to the biological material that is 
synthesized on a substrate or deposited on a slide, as described above, but to what is 
referred to herein as the "target." A target is a molecule that has an affinity for a given 
probe. Targets may be naturally-occurring or man-made molecules. Also, they can be 
employed in their unaltered state or as aggregates with other species. The samples or 
targets are processed so that, typically, they are spatially associated with certain 
probes in the probe array. For example, one or more tagged targets may be 
distributed over the probe array. 

[0053] Targets may be attached, covalently or noncovalently, to a binding member, either 
directly or via a specific binding substance. Examples of targets that can be employed 
in accordance with this invention include, but are not restricted to, antibodies, cell 
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membrane receptors, monoclonal antibodies and antisera reactive with specific 
antigenic determinants (such as on viruses, cells or other materials), drugs, 
oligonucleotides, nucleic acids, peptides, cofactors, lectins, sugars, polysaccharides, 
cells, cellular membranes, and organelles. Targets are sometimes referred to in the art 
as anti-probes. As the term target is used herein, no difference in meaning is 
intended. Typically, a "probe-target pair" is formed when two macromolecules have 
combined through molecular recognition to form a complex. 

[0054] The probes of the arrays in some implementations comprise nucleic acids that are 
synthesized by methods including the steps of activating regions of a substrate and 
then contacting the substrate with a selected monomer solution. The term "monomer" 
generally refers to any member of a set of molecules that can be joined together to 
form an oligomer or polymer. The set of monomers useful in the present invention 
includes, but is not restricted to, for the example of (poly)peptide synthesis, the set of 
L-amino acids, D-amino acids, or synthetic amino acids. As used herein, "monomer" 
refers to any member of a basis set for synthesis of an oligomer. For example, dimers 
of L-amino acids form a basis set of 400 "monomers" for synthesis of polypeptides. 
Different basis sets of monomers may be used at successive steps in the synthesis of 
a polymer. The term "monomer" also refers to a chemical subunit that can be 
combined with a different chemical subunit to form a compound larger than either 
subunit alone. In addition, the terms "biopolymer" and "biological polymer" generally 
refer to repeating units of biological or chemical moieties. Representative biopolymers 
include, but are not limited to, nucleic acids, oligonucleotides, amino acids, proteins, 
peptides, hormones, oligosaccharides, lipids, glycolipids, lipopolysaccharides, 
phospholipids, synthetic analogues of the foregoing, including, but not limited to, 
inverted nucleotides, peptide nucleic acids, Meta-DNA, and combinations of the 
above. "Biopolymer synthesis" is intended to encompass the synthetic production, 
both organic and inorganic, of a biopolymer. Related to the term "biopolymer" is the 
term "biomonomer" that generally refers to a single unit of biopolymer, or a single 
unit that is not part of a biopolymer. Thus, for example, a nucleotide is a biomonomer 
within an oligonucleotide biopolymer, and an amino acid is a biomonomer within a 
protein or peptide biopolymer; avidin, biotin, antibodies, antibody fragments, etc., for 
example, are also biomonomers. 
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[0055] As used herein, nucleic acids may include any polymer or oligomer of nucleosides 
or nucleotides (polynucleotides or oligonucleotides) that include pyrimidine and/or 
purine bases, preferably cytosine, thymine, and uracil, and adenine and guanine, 
respectively. An "oligonucleotide" or "polynucleotide" is a nucleic acid ranging from at 
least 2, preferable at least 8, and more preferably at least 20 nucleotides in length or 
a compound that specifically hybridizes to a polynucleotide. Polynucleotides of the 
present invention include sequences of deoxyribonucleic acid (DNA) or ribonucleic 
acid (RNA), which may be isolated from natural sources, recombinantly produced or 
artificially synthesized and mimetics thereof. A further example of a polynucleotide in 
accordance with the present invention may be peptide nucleic acid (PNA) in which the 
constituent bases are joined by peptides bonds rather than phosphodiester linkage, as 
described in Nielsen et aL, Science 254:1497-1 500 (1991); Nielsen, Curr. Opin. 
Biotechnol., 10:71-75 (1999), both of which are hereby incorporated by reference 
herein. The invention also encompasses situations in which there is a nontraditional 
base pairing such as Hoogsteen base pairing that has been identified in certain tRNA 
molecules and postulated to exist in a triple helix. "Polynucleotide" and 
"oligonucleotide" may be used interchangeably in this application. 

[0056] Additionally, nucleic acids according to the present invention may include any 

polymer or oligomer of pyrimidine and purine bases, preferably cytosine (C), thymine 
(T), and uracil (U), and adenine (A) and guanine (G), respectively. See Albert L. 
Lehninger, PRINCIPLES OF BIOCHEMISTRY, at 793-800 (Worth Pub. 1982). Indeed, the 
present invention contemplates any deoxyribonucleotide, ribonucleotide or peptide 
nucleic acid component, and any chemical variants thereof, such as methylated, 
hydroxymethylated or glucosylated forms of these bases, and the like. The polymers 
or oligomers may be heterogeneous or homogeneous in composition, and may be 
isolated from naturally occurring sources or may be artificially or synthetically 
produced. In addition, the nucleic acids may be deoxyribonucleic acid (DNA) or 
ribonucleic acid (RNA), or a mixture thereof, and may exist permanently or 
transitionally in single-stranded or double-stranded form, including homoduplex, 
heteroduplex, and hybrid states. 

[0057] As notec | a nucleic acid library or array typically is an intentionally created 

collection of nucleic acids that can be prepared either synthetically or biosynthetically 
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in a variety of different formats (e.g., libraries of soluble molecules; and libraries of 
oligonucleotides tethered to resin beads, silica chips, or other solid supports). 
Additionally, the term "array" is meant to include those libraries of nucleic acids that 
can be prepared by spotting nucleic acids of essentially any length (e.g., from 1 to 
about 1000 nucleotide monomers in length) onto a substrate. The term "nucleic acid" 
as used herein refers to a polymeric form of nucleotides of any length, either 
ribonucleotides, deoxyribonucleotides or peptide nucleic acids (PNAs), that comprise 
purine and pyrimidine bases, or other natural, chemically or biochemically modified, 
non-natural, or derivatized nucleotide bases. The backbone of the polynucleotide can 
comprise sugars and phosphate groups, as may typically be found in RNA or DNA, or 
modified or substituted sugar or phosphate groups. A polynucleotide may comprise 
modified nucleotides, such as methylated nucleotides and nucleotide analogs. The 
sequence of nucleotides may be interrupted by non-nucleotide components. Thus the 
terms nucleoside, nucleotide, deoxynucleoside and deoxynucleotide generally include 
analogs such as those described herein. These analogs are those molecules having 
some structural features in common with a naturally occurring nucleoside or 
nucleotide such that when incorporated into a nucleic acid or oligonucleotide 
sequence, they allow hybridization with a naturally occurring nucleic acid sequence in 
solution. Typically, these analogs are derived from naturally occurring nucleosides and 
nucleotides by replacing and/or modifying the base, the ribose or the phosphodiester 
moiety. The changes can be tailor made to stabilize or destabilize hybrid formation or 
enhance the specificity of hybridization with a complementary nucleic acid sequence 
as desired. Nucleic acid arrays that are useful in the present invention include those 
that are commercially available from Affymetrix, Inc. of Santa Clara, California, under 
the registered trademark "GeneChip ® ." Example arrays are shown on the website at 
affymetrix.com. 

[0058] 

In some embodiments, a probe may be surface immobilized. Examples of probes 
that can be investigated in accordance with this invention include, but are not 
restricted to, agonists and antagonists for cell membrane receptors, toxins and 
venoms, viral epitopes, hormones (e.g., opioid peptides, steroids, etc.), hormone 
receptors, peptides, enzymes, enzyme substrates, cofactors, drugs, lectins, sugars, 
oligonucleotides, nucleic acids, oligosaccharides, proteins, and monoclonal 
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antibodies. As non-limiting examples, a probe may refer to a nucleic acid, such as an 
oligonucleotide, capable of binding to a target nucleic acid of complementary 
sequence through one or more types of chemical bonds, usually through 
complementary base pairing, usually through hydrogen bond formation. A probe may 
include natural (i.e. A, G, U, C, or T) or modified bases (7-deazaguanosine, inosine, 
etc.). In addition, the bases in probes may be joined by a linkage other than a 
phosphodiester bond, so long as the bond does not interfere with hybridization. Thus, 
probes may be peptide nucleic acids in which the constituent bases are joined by 
peptide bonds rather than phosphodiester linkages. Other examples of probes include 
antibodies used to detect peptides or other molecules, or any ligands for detecting its 
binding partners. Probes of other biological materials, such as peptides or 
polysaccharides as non-limiting examples, may also be formed. For more details 
regarding possible implementations, see U.S. Patent No. 6,1 56,501 , hereby 
incorporated by reference herein in its entirety for all purposes. When referring to 
targets or probes as nucleic acids, it should be understood that these are illustrative 
embodiments that are not to limit the invention in any way. 

[0059] Furthermore, to avoid confusion, the term "probe" is used herein to refer to 

probes such as those synthesized according to the VLSIPS ™ technology; the biological 
materials deposited so as to create spotted arrays; and materials synthesized, 
deposited, or positioned to form arrays according to other current or future 
technologies. Thus, microarrays formed in accordance with any of these technologies 
may be referred to generally and collectively hereafter for convenience as "probe 
arrays." Moreover, the term "probe" is not limited to probes immobilized in array 
format. Rather, the functions and methods described herein may also be employed 
with respect to other parallel assay devices. For example, these functions and 
methods may be applied with respect to probe-set identifiers that identify probes 
immobilized on or in beads, optical fibers, or other substrates or media. 

[0060] | n accorc | ance with some implementations, some targets hybridize with probes 
and remain at the probe locations, while non-hybridized targets are washed away. 
These hybridized targets, with their tags or labels, are thus spatially associated with 
the probes. The term "hybridization" refers to the process in which two single- 
stranded polynucleotides bind non-covalently to form a stable double-stranded 
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polynucleotide. The term "hybridization" may also refer to triple-stranded 
hybridization, which is theoretically possible. The resulting (usually) double-stranded 
polynucleotide is a "hybrid." The proportion of the population of polynucleotides that 
forms stable hybrids is referred to herein as the "degree of hybridization." 
Hybridization probes usually are nucleic acids (such as oligonucleotides) capable of 
binding in a base-specific manner to a complementary strand of nucleic acid. Such 
probes include peptide nucleic acids, as described in Nielsen et al., Science 254:1497- 
1 500 (1991) or Nielsen Curr. Opin. Biotechnol., 10:71-75 (1999) (both of which are 
hereby incorporated herein by reference), and other nucleic acid analogs and nucleic 
acid mimetics. The hybridized probe and target may sometimes be referred to as a 
probe-target pair. Detection of these pairs can serve a variety of purposes, such as to 
determine whether a target nucleic acid has a nucleotide sequence identical to or 
different from a specific reference sequence. See, for example, U.S. Patent No. 
5,837,832, referred to and incorporated above. Other uses include gene expression 
monitoring and evaluation (see, e.g., U.S. Patent No. 5,800,992 to Fodor, et al.; U.S. 
Patent No. 6,040,1 38 to Lockhart, et al.; and International App. No. PCT/US98/1 51 51 , 
published as WO99/05323, to Balaban, et al.), genotyping (U.S. Patent No. 5,856,092 
to Dale, et al.), or other detection of nucleic acids. The '992, '1 38, and '092 patents, 
and publication WO99/05323, are incorporated by reference herein in their entireties 
for all purposes. 

[0061] The present invention also contemplates signal detection of hybridization between 
probes and targets in certain preferred embodiments. See U.S. Pat. Nos. 5,143,854, 
5,578,832; 5,631 ,734; 5,936,324; 5,981 ,956; 6,025,601 incorporated above and in 
U.S. Patent Nos. 5,834,758, 6,141,096; 6,185,030; 6,201,639; 6,218,803; and 
6,225,625, in U.S. Patent application 60/364,731 and in PCT Application 
PCT/US99/06097 (published as W099/47964), each of which also is hereby 
incorporated by reference in its entirety for all purposes. 

[0062] ^ system and method for efficiently synthesizing probe arrays using masks is 

described in U.S. Patent Application, Serial No. 09/824,931 , filed April 3, 2001 , that is 
hereby incorporated by reference herein in its entirety for all purposes. A system and 
method for a rapid and flexible microarray manufacturing and online ordering system 
is described in U.S. Provisional Patent Application, Serial No. 60/265,103 filed January 
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29, 2001 , that also is hereby incorporated herein by reference in its entirety for all 
purposes. Systems and methods for optical photolithography without masks are 
described in U.S. Patent No. 6,271,957 and in U.S. Patent Application No. 09/683,374 
filed December 19, 2001 , both of which are hereby incorporated by reference herein 
in their entireties for all purposes. 

[0063] 

As noted, various techniques exist for depositing probes on a substrate or 
support. For example, "spotted arrays" are commercially fabricated, typically on 
microscope slides. These arrays consist of liquid spots containing biological material 
of potentially varying compositions and concentrations. For instance, a spot in the 
array may include a few strands of short oligonucleotides in a water solution, or it may 
include a high concentration of long strands of complex proteins. The Affymetrix ® 
417™ Arrayer and 427 ™ Arrayer are devices that deposit densely packed arrays of 
biological materials on microscope slides in accordance with these techniques. 
Aspects of these and other spot arrayers are described in U.S. Patents Nos. 6,040,1 93 
and 6,136,269 and in PCT Application No. PCT/US99/00730 (International Publication 
Number WO 99/36760) incorporated above and in U.S. Patent Application Serial No. 
09/683,298 hereby incorporated by reference in its entirety for all purposes. Other 
techniques for generating spotted arrays also exist. For example, U.S. Patent No. 
6,040,1 93 to Winkler, et al. is directed to processes for dispensing drops to generate 
spotted arrays. The '1 93 patent, and U.S. Patent No. 5,885,837 to Winkler, also 
describe the use of micro-channels or micro-grooves on a substrate, or on a block 
placed on a substrate, to synthesize arrays of biological materials. These patents 
further describe separating reactive regions of a substrate from each other by inert 
regions and spotting on the reactive regions. The '193 and '837 patents are hereby 
incorporated by reference in their entireties. Another technique is based on ejecting 
jets of biological material to form a spotted array. Other implementations of the 
jetting technique may use devices such as syringes or piezo electric pumps to propel 
the biological material. It will be understood that the foregoing are non-limiting 
examples of techniques for synthesizing, depositing, or positioning biological 
material onto or within a substrate. For example, although a planar array surface is 
preferred in some implementations of the foregoing, a probe array may be fabricated 
on a surface of virtually any shape or even a multiplicity of surfaces. Arrays may 
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comprise probes synthesized or deposited on beads, fibers such as fiber optics, glass, 
silicon, silica or any other appropriate substrate, see U.S. Patent No. 5,800,992 
referred to and incorporated above and U.S. Patent Nos. 5,770,358, 5,789,162, 
5,708,1 53 and 6,361 ,947 all of which are hereby incorporated in their entireties for 
all purposes. Arrays may be packaged in such a manner as to allow for diagnostics or 
other manipulation in an all inclusive device, see for example, U.S. Pat. Nos. 
5,856,1 74 and 5,922,591 hereby incorporated in their entireties by reference for all 
purposes. 

[0064] Probes typically are able to detect the expression of corresponding genes or ESTs 
by detecting the presence or abundance of mRNA transcripts present in the target. 
This detection may, in turn, be accomplished in some implementations by detecting 
labeled cRNA that is derived from cDNA derived from the mRNA in the target. 

[0065] The terms "mRNA" and "mRNA transcripts" as used herein, include, but not limited 
to pre-mRNA transcript(s), transcript processing intermediates, mature mRNA(s) ready 
for translation and transcripts of the gene or genes, or nucleic acids derived from the 
mRNA transcript(s). Thus, mRNA derived samples include, but are not limited to, 
mRNA transcripts of the gene or genes, cDNA reverse transcribed from the mRNA, 
cRNA transcribed from the cDNA, DNA amplified from the genes, RNA transcribed 
from amplified DNA, and the like. 

[0066] In general, a group of probes, sometimes referred to as a probe set, contains sub- 
sequences in unique regions of the transcripts and does not correspond to a full gene 
sequence. Further details regarding the design and use of probes and probe sets are 
provided in PCT Application Serial No. PCT/US 01/02316, filed January 24, 2001 
incorporated above; and in U.S. Patent No. 6,188,783 and in U.S. Patent Applications 
Serial No. 09/721,042, filed on November 21, 2000, Serial No. 09/718,295, filed on 
November, 21, 2000, Serial No. 09/745,965, filed on December 21, 2000, and Serial 
No. 09/764,324, filed on January 16, 2001, all of which patent and patent 
applications are hereby incorporated herein by reference in their entireties for all 
purposes. 

[0067] Scanner 190: Figure 1 is a functional block diagram of a system that is suitable 
for, among other things, analyzing probe arrays that have been hybridized with 
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labeled targets. Representative hybridized probe arrays 103 of Figure 1 may include 
probe arrays of any type, as noted above. Labeled targets in hybridized probe arrays 
103 may be detected using various commercial devices, referred to for convenience 
hereafter as "scanners." An illustrative device is shown in Figure 1 as scanner 1 90. In 
some implementations, scanners image the targets by detecting fluorescent or other 
emissions from the labels, or by detecting transmitted, reflected, or scattered 
radiation. These processes are generally and collectively referred to hereafter for 
convenience simply as involving the detection of "emissions." Various detection 
schemes are employed depending on the type of emissions and other factors. A 
typical scheme employs optical and other elements to provide excitation light and to 
selectively collect the emissions. Also included in some implementations are various 
light-detector systems employing photodiodes, charge-coupled devices, 
photomultiplier tubes, or similar devices to register the collected emissions. 

[0068] Methods and apparatus for signal detection and processing of intensity data are 
disclosed in, for example, U.S. Patents Numbers 5,143,854, 5,578,832, 5,631,734, 
5,800,992, 5,834,758, 5,856,092, 5,936,324, 5,981,956, 6,025,601, 6,090,555, 
6,141,096, 6,185,030, 6,201,639, 6,218,803 and 6,225,625, in U.S. Patent 
application 60/364,731 and in PCT Application PCT/US99/06097 (published as 
W099/47964) incorporated above, and in U.S. Patent Nos. 5,547,839 and 5,902,723 
hereby incorporated by reference in their entireties for all purposes. Other scanners or 
scanning systems are described in U.S. Patent Applications, Serial Nos. 09/682,837 
filed October 23, 2001 , 09/683,216 filed December 3, 2001 , and 09/683,2 1 7 filed 
December 3, 2001, 09/683,219 filed December 3, 2001, each of which is hereby 
incorporated by reference in its entirety for all purposes. 

[0069] The present invention may also make use of various computer program products 
and software for a variety of purposes, such as probe design, management of data, 
analysis, and instrument operation. See, U.S. Patent Nos. 5,593,839, 5,795,71 6, 
5,974,164, 6,090,555, 6,188,783 incorporated above and U.S. Patent Nos. 5,733,729, 
6,066,454, 6,185,561, 6,223,127, 6,229,91 1 and 6,308,170, hereby incorporated 
herein in their entireties for all purposes.. 

[0070] 

Scanner 190 provides data representing the intensities (and possibly other 
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characteristics, such as color) of the detected emissions, as well as the locations on 
the substrate where the emissions were detected. The data typically are stored in a 
memory device, such as system memory 1 20 of user computer 1 00, in the form of a 
data file or other data storage form or format. One type of data file, such as image 
data file 212 shown in Figure 2, typically includes intensity and location information 
corresponding to elemental sub-areas of the scanned substrate. The term "elemental" 
in this context means that the intensities, and/or other characteristics, of the 
emissions from this area each are represented by a single value. When displayed as an 
image for viewing or processing, elemental picture elements, or pixels, often 
represent this information. Thus, for example, a pixel may have a single value 
representing the intensity of the elemental sub-area of the substrate from which the 
emissions were scanned. The pixel may also have another value representing another 
characteristic, such as color. For instance, a scanned elemental sub-area in which 
high-intensity emissions were detected may be represented by a pixel having high 
luminance (hereafter, a "bright" pixel), and low-intensity emissions may be 
represented by a pixel of low luminance (a "dim" pixel). Alternatively, the chromatic 
value of a pixel may be made to represent the intensity, color, or other characteristic 
of the detected emissions. Thus, an area of high-intensity emission may be displayed 
as a red pixel and an area of low-intensity emission as a blue pixel. As another 
example, detected emissions of one wavelength at a particular sub-area of the 
substrate may be represented as a red pixel, and emissions of a second wavelength 
detected at another sub-area may be represented by an adjacent blue pixel. Many 
other display schemes are known. Two examples of image data are data files in the 
form *.dat or *.tif as generated respectively by Affymetrix ® Microarray Suite based on 
images scanned from GeneChip ® arrays, and by Affymetrix • Jaguar ™ software based 
on images scanned from spotted arrays. 

[0071] 

Probe-Array Analysis Applications 199: Generally, a human being may inspect a 
printed or displayed image constructed from the data in an image file and may 
identify those cells that are bright or dim, or are otherwise identified by a pixel 
characteristic (such as color). However, it frequently is desirable to provide this 
information in an automated, quantifiable, and repeatable way that is compatible with 
various image processing and/or analysis techniques. For example, the information 
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may be provided for processing by a computer application that associates the 
locations where hybridized targets were detected with known locations where probes 
of known identities were synthesized or deposited. Other methods include tagging 
individual synthesis or support substrates (such as beads) using chemical, biological, 
electro-magnetic transducers or transmitters, and other identifiers. Information such 
as the nucleotide or monomer sequence of target DNA or RNA may then be deduced. 
Techniques for making these deductions are described, for example, in U.S. Patent 
No. 5,733,729 and in U.S. Patent No. 5,837,832, noted and incorporated above. 

[0072] 

A variety of computer software applications are commercially available for 
controlling scanners (and other instruments related to the hybridization process, such 
as hybridization chambers), and for acquiring and processing the image files provided 
by the scanners. Examples are the Jaguar ™ application from Affymetrix, Inc., aspects 
of which are described in PCT Application PCT/US 01/26390 and in U.S. Patent 
Applications, Serial Nos. 09/681,819, 09/682,071, 09/682,074, and 09/682,076, and 
the Microarray Suite application from Affymetrix, filed aspects of which are described 
in U.S. Provisional Patent Applications, Serial Nos. 60/220,587, 60/220,645, 
60/226,999 and 60/312,906, and U.S. Patent Application Serial No. 1 0/21 9,882, all 
of which are hereby incorporated herein by reference in their entireties for all 
purposes. For example, image data in image data file 212 may be operated upon to 
generate intermediate results such as so-called cell intensity files (*.cel) and chip files 
(*.chp), generated by Microarray Suite or spot files (*.spt) generated by Jaguar ™ 
software. For convenience, the terms "file" or "data structure" may be used herein to 
refer to the organization of data, or the data itself generated or used by executables 
199A and executable counterparts of other applications. However, it will be 
understood that any of a variety of alternative techniques known in the relevant art for 
storing, conveying, and/or manipulating data may be employed, and that the terms 
"file" and "data structure" therefore are to be interpreted broadly. In the illustrative 
case in which image data file 212 is derived from a GeneChip ® probe array, and in 
which Microarray Suite generates cell intensity file 21 6, file 216 may contain, for each 
probe scanned by scanner 190, a single value representative of the intensities of 
pixels measured by scanner 1 90 for that probe. Thus, this value is a measure of the 
abundance of tagged cRNA's present in the target that hybridized to the 
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corresponding probe. Many such cRNA's may be present in each probe, as a probe on 
a GeneChip ® probe array may include, for example, millions of oligonucleotides 
designed to detect the cRNA's. The resulting data stored in the chip file may include 
degrees of hybridization, absolute and/or differential (over two or more experiments) 
expression, genotype comparisons, detection of polymorphisms and mutations, and 
other analytical results. In another example, in which executables 1 99A includes 
image data from a spotted probe array, the resulting spot file includes the intensities 
of labeled targets that hybridized to probes in the array. Further details regarding cell 
files, chip files, and spot files are provided in U.S. Provisional Patent Application Nos. 
60/220,645, 60/220,587, and 60/226,999, incorporated by reference above. 

[0073] 

In the present example, in which executables 1 99A may include aspects of 
Affymetrix ® Microarray Suite, the chip file is derived from analysts of the cell file 
combined in some cases with information derived from library files (not shown) that 
specify details regarding the sequences and locations of probes and controls. 
Laboratory or experimental data may also be provided to the software for inclusion in 
the chip file. For example, an experimenter and/or automated data input devices or 
programs (not shown) may provide data related to the design or conduct of 
experiments. As a non-limiting example related to the processing of an Affymetrix ® 
GeneChip ® probe array, the experimenter may specify an Affymetrix catalog or 
custom chip type (e.g., Human Genome U95Av2 chip) either by selecting from a 
predetermined list presented by Microarray Suite or by scanning a bar code related to 
a chip to read its type. Microarray Suite may associate the chip type with various 
scanning parameters stored in data tables including the area of the chip that is to be 
scanned, the location of chrome borders on the chip used for auto-focusing, the 
wavelength or intensity of laser light to be used in reading the chip, and so on. Other 
experimental or laboratory data may include, for example, the name of the 
experimenter, the dates on which various experiments were conducted, the 
equipment used, the types of fluorescent dyes used as labels, protocols followed, and 
numerous other attributes of experiments. As noted, executables 1 99A may apply 
some of this data in the generation of intermediate results. For example, information 
about the dyes may be incorporated into determinations of relative expression. Other 
data, such as the name of the experimenter, may be processed by executables 1 99A 
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or may simply be preserved and stored in files or other data structures. Any of these 
data may be provided, for example over a network, to a laboratory information 
management server computer, such as user database server 41 2 of Figure 4, 
configured to manage information from large numbers of experiments. Data analysis 
program 210 may also generate various types of plots, graphs, tables, and other 
tabular and/or graphical representations of analytical data such as contained in file 
21 5. As will be appreciated by those skilled in the relevant art, the preceding and 
following descriptions of files generated by executables 1 99A are exemplary only, and 
the data described, and other data, may be processed, combined, arranged, and/or 
presented in many other ways. 

[0074] The processed image files produced by these applications often are further 

processed to extract additional data. In particular, data-mining software applications 
often are used for supplemental identification and analysis of biologically interesting 
patterns or degrees of hybridization of probe sets. An example of a software 
application of this type is the Affymetrix ® Data Mining Tool, illustrated in Figure 2 as 
Data Mining Tool 220 and described in U.S. Provisional Patent Applications, Serial Nos. 
60/274,986 and 60/312,256, and U.S. Patent Application Serial No. 09/683,980 each 
of which is hereby incorporated herein by reference in their entireties for all purposes. 
Software applications also are available for storing and managing the enormous 
amounts of data that often are generated by probe-array experiments and by the 
image-processing and data-mining software noted above. An example of these data- 
management software applications is the Affymetrix ® Laboratory Information 
Management System (LIMS), aspects of which illustrated as Laboratory Information 
Management System Application 225 and are described in U.S. Provisional Patent 
Applications, Serial Nos. 60/220,587 and 60/220,645, incorporated above and in U.S. 
Patent Application No. 09/682,098 hereby incorporated by reference herein in its 
entirety for all purposes. In addition, various proprietary databases accessed by 
database management software, such as the Affymetrix ® EASI (Expression Analysis 
Sequence Information) database and database software, provide researchers with 
associations between probe sets and gene or EST identifiers. 

0075] p Qr conven i ence 0 f reference, these types of computer software applications (i.e., 
for acquiring and processing image files, data mining, data management, and various 
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database and other applications related to probe-array analysis) are generally and 
collectively represented in Figure 1 as probe-array analysis applications 199. Figure 2 
is a functional block diagram of probe-array analysis applications 1 99 as illustratively 
stored for execution (as executable code 1 99A corresponding to applications 1 99) in 
system memory 1 20 of user computer 1 00 of Figure 1 . 

[0076] As will be appreciated by those skilled in the relevant art, it is not necessary that 
applications 199 be stored on and/or executed from computer 100; rather, some or 
all of applications 1 99 may be stored on and/or executed from an applications server 
or other computer platform to which computer 1 00 is connected in a network. For 
example, it may be particularly advantageous for applications involving the 
manipulation of large databases, such as Affymetrix • LIMS or Affymetrix ® Data 
Mining Tool (DMT), to be executed from a database server such as user database 
server 41 2 of Figure 4. Alternatively, LIMS, DMT, and/or other applications may be 
executed from computer 100, but some or all of the databases upon which those 
applications operate may be stored for common access on server 41 2 (perhaps 
together with a database management program, such as the Oracle ® 8.0.5 database 
management system from Oracle Corporation). Such networked arrangements may be 
implemented in accordance with known techniques using commercially available 
hardware and software, such as those available for implementing a local-area network 
or wide-area network. A local network is represented in Figure 4 by the connection of 
user computer 1 00 to user database server 412 (and to user-side Internet client 41 0, 
which may be the same computer) via network cable 480. Similarly, scanner 1 90 (or 
multiple scanners) may be made available to a network of users over cable 480 both 
for purposes of controlling scanner 190 and for receiving data input from it. 

[0077] j n some implementations, it may be convenient for user 101 to group probe-set 
identifiers 222 for batch transfer of information or to otherwise analyze or process 
groups of probe sets together. For example, as described below, user 1 01 may wish 
to obtain annotation information via portal 400 related to one or more probe sets 
identified by their respective probe set identifiers. Rather than obtaining this 
information serially, user 1 01 may group probe sets together for batch processing. 
Various known techniques may be employed for associating probe set identifiers, or 
data related to those identifiers, together. For instance, user 101 may generate a tab 
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delimited *.txt file including a list of probe set identifiers for batch processing. This 
file or another file or data structure for providing a batch of data (hereafter referred to 
for convenience simply as a "batch file"), may be any kind of list, text, data structure, 
or other collection of data in any format. The batch file may also specify what kind of 
information user 1 01 wishes to obtain with respect to all, or any combination of, the 
identified probe sets. In some implementations, user 1 01 may specify a name or other 
user-specified identifier to represent the group of probe-set identifiers specified in 
the text file or otherwise specified by user 1 01 . This user-specified identifier may be 
stored by one of executables 1 99A, or by elements of portal 400 described below, so 
that user 1 01 may employ it in future operations rather than providing the associated 
probe-set identifiers in a text file or other format. Thus, for example, user 1 01 may 
formulate one or more queries associated with a particular user-specified identifier, 
resulting in a batch transfer of information from portal 400 to user 101 related to the 
probe-set identifiers that user 101 has associated with the user-specified identifier. 
Alternatively, user 1 01 may initiate a batch transfer by providing the text file of 
probe-set identifiers. In any of these cases, user 1 01 may formulate queries to obtain, 
in a single batch operation, probe set records, lists of probe sets sorted into 
functional groups, protein domain information, sequence homology information, 
metabolic pathway information, BLAST similarity searches, array content information, 
and any other information available via portal 400. Similarly, user 101 may provide 
information, such as laboratory or experimental information, related to a number of 
probe sets by a batch operation rather than serial ones. The probe sets may be 
grouped by experiments, by similarity of probe sets (e.g., probe sets representing 
genes having similar annotations, such as related to transcription regulation), or any 
other type of grouping. For example, user 1 01 may assign a user-specified identifier 
(e.g., "experiments of January 1") to a series of experiments and submit probe-set 
identifiers in user-selected categories (e.g., identifying probe sets that were up- 
regulated by a specified amount) and provide the experimental information to portal 
400 for data storage and/or analysis. 

[0078] 

User Computer 1 00: User computer 1 00, shown in Figure 1 , may be a computing 
device specially designed and configured to support and execute some or all of the 
functions of probe array applications 1 99. Computer 1 00 also may be any of a variety 
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of types of general-purpose computers such as a personal computer, network server, 
workstation, or other computer platform now or later developed. Computer 1 00 
typically includes known components such as a processor 105, an operating system 
1 1 0, a graphical user interface (GUI) controller 1 1 5, a system memory 1 20, memory 
storage devices 1 2 5, and input-output controllers 1 30. It will be understood by those 
skilled in the relevant art that there are many possible configurations of the 
components of computer 1 00 and that some components that may typically be 
included in computer 100 are not shown, such as cache memory, a data backup unit, 
and many other devices. Processor 105 may be a commercially available processor 
such as a Pentium ® processor made by Intel Corporation, a SPARC ® processor made 
by Sun Microsystems, or it may be one of other processors that are or will become 
available. Processor 105 executes operating system 1 10, which may be, for example, 
a Windows ® -type operating system (such as Windows NT • 4.0 with SP6a) from the 
Microsoft Corporation; a Unix • or Linux-type operating system available from many 
vendors; another or a future operating system; or some combination thereof. 
Operating system 1 10 interfaces with firmware and hardware in a well-known manner, 
and facilitates processor 105 in coordinating and executing the functions of various 
computer programs that may be written in a variety of programming languages. 
Operating system 1 10, typically in cooperation with processor 105, coordinates and 
executes functions of the other components of computer 100. Operating system 1 10 
also provides scheduling, input-output control, file and data management, memory 
management, and communication control and related services, all in accordance with 
known techniques. 

[0079] 

System memory 1 20 may be any of a variety of known or future memory storage 
devices. Examples include any commonly available random access memory (RAM), 
magnetic medium such as a resident hard disk or tape, an optical medium such as a 
read and write compact disc, or other memory storage device. Memory storage device 
1 25 may be any of a variety of known or future devices, including a compact disk 
drive, a tape drive, a removable hard disk drive, or a diskette drive. Such types of 
memory storage device 125 typically read from, and/or write to, a program storage 
medium (not shown) such as, respectively, a compact disk, magnetic tape, removable 
hard disk, or floppy diskette. Any of these program storage media, or others now in 
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use or that may later be developed, may be considered a computer program product. 
As will be appreciated, these program storage media typically store a computer 
software program and/or data. Computer software programs, also called computer 
control logic, typically are stored in system memory and/or the program storage 
device used in conjunction with memory storage device 12 5. 

[0080] In some embodiments, a computer program product is described comprising a 

computer usable medium having control logic (computer software program, including 
program code) stored therein. The control logic, when executed by processor 105, 
causes processor 105 to perform functions described herein. In other embodiments, 
some functions are implemented primarily in hardware using, for example, a hardware 
state machine. Implementation of the hardware state machine so as to perform the 
functions described herein will be apparent to those skilled in the relevant arts. 

[0081] Input-output controllers 130 could include any of a variety of known devices for 
accepting and processing information from a user, whether a human or a machine, 
whether local or remote. Such devices include, for example, modem cards, network 
interface cards, sound cards, or other types of controllers for any of a variety of 
known input devices 1 02. Output controllers of input-output controllers 1 30 could 
include controllers for any of a variety of known display devices 1 80 for presenting 
information to a user, whether a human or a machine, whether local or remote. If one 
of display devices 1 80 provides visual information, this information typically may be 
logically and/or physically organized as an array of picture elements, sometimes 
referred to as pixels. Graphical user interface (GUI) controller 1 1 5 may comprise any 
of a variety of known or future software programs for providing graphical input and 
output interfaces between computer 100 and user 101, and for processing user 
inputs. In the illustrated embodiment, the functional elements of computer 100 
communicate with each other via system bus 1 04. Some of these communications may 
be accomplished in alternative embodiments using network or other types of remote 
communications. 

[0082] 

As will be evident to those skilled in the relevant art, applications 1 99, if 
implemented in software, may be loaded into system memory 120 and/or memory 
storage device 1 25 through one of input devices 1 02. All or portions of applications 
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1 99 may also reside in a read-only memory or similar device of memory storage 
device 1 25, such devices not requiring that applications 1 99 first be loaded through 
input devices 1 02. It will be understood by those skilled in the relevant art that 
applications 199, or portions of it, may be loaded by processor 105 in a known 
manner into system memory 1 20, or cache memory (not shown), or both, as 
advantageous for execution. 

[0083] Conventional Techniques for Obtaining Genomic Data: A number of conventional 
approaches for obtaining genomic data over the Internet are available, some of which 
are described in the book edited by Ouelette and Baxevanis, incorporated by reference 
above. Figure 3 is a functional block diagram representing one simplified example. As 
shown in Figure 3, user 1 01 may consult any of a number of public or other sources 
to obtain accession numbers 224'. As represented by manual operation 312, user 101 
initiates request 31 2 by accessing through any web browser the Internet web site of 
the National Center for Biotechnology Information (NCBI) of the National Library of 
Medicine and the National Institutes of Health (as of November 2002, accessible at the 
Internet URL http://www.ncbi.nlm.nih.gov/ ). In particular, user 1 01 may access the 
Entrez search and retrieval system that provides information from various databases 
at NCBI . These databases provide information regarding nucleotide sequences, 
protein sequences, macromolecular structures, whole genomes, and publication data 
related thereto. It is illustratively assumed that user 101 accesses in this manner NCBI 
Entrez nucleotide database 31 4 and receives information including gene or EST 
sequences 316. Particularly if accession numbers 224 f represents a large number 
(e.g., one hundred) of EST's or genes of interest, as may easily be the case following 
analysis of probe array experiments, the tasks thus far described may take significant 
time, perhaps hours. 

[0084] ^ genome is all the genetic material in the chromosomes of an organism. In some 
instances, the term genome may refer to the chromosomal DNA. A genome may be 
multichromosomal such that the DNA is distributed among a plurality of individual 
chromosomes in a cell. For example, in human there are 22 pairs of chromosomes 
plus a gender associated XX or XY pair. DNA derived from the genetic material in the 
chromosomes of a particular organism is genomic DNA. The term genome may also 
refer to genetic materials from organisms that do not have chromosomal structure. In 
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addition, the term genome may refer to mitochondria DNA. A genomic library is a 
collection of DNA fragments that represents the whole or a portion of a genome. 
Frequently, a genomic library is a collection of clones made from a set of randomly 
generated, sometimes overlapping DNA fragments representing the entire genome or 
a portion of the genome of an organism. 

[0085] User 101 typically copies sequence information from sequences 316 and pastes 
this information into an HTML document accessible through NCBI's BLAST web pages 
324 (as of November 2002, accessible at http://www.ncbi.nlm.nih.gov/BLAST/ ). This 
operation, which also may be time consuming and tedious if many sequences are 
involved, is represented by user-initiated batch BLAST request 322 of Figure 3. BLAST 
is an acronym for Basic Local Alignment Search Tool, and, as is well known in the art, 
consists of similarity search programs that interrogate sequence databases for both 
protein and DNA using heuristic algorithms to seek local alignments. For example, 
user 101 may conduct a BLAST search using the "blastn" nucleotide sequence 
database. Results of this batch BLAST search, represented by similar nucleotide 
and/or protein sequence data 326, on occasion may not be available to user 101 for 
many minutes or even hours. User 1 01 may then initiate comparisons and evaluations 
332, which may be conducted manually or using various software tools. User 1 01 may 
subsequently issue report 334 interpreting the findings of the searches and positing 
strategies and requirements for follow-on experiments. 

[0086] Inputs to Genomic Portal 400 from User 1 01 : The present invention may have 

preferred embodiments that include methods for providing genetic information over 
networks such as the Internet as shown in U.S. Patent application 60/349,546, 
incorporated above and U.S. Patent applications 1 0/063,559, 60/376,003, 
60/394,574 and 60/403,381, hereby incorporated by reference herein in their 
entireties for all purposes. Figure 4 is a functional block diagram showing an 
illustrative configuration by which user 1 01 may connect with genomic web portal 
400. It will be understood that Figure 4 is simplified and is illustratively only, and that 
many implementations and variations of the network and Internet connections shown 
in Figure 4 will be evident to those of ordinary skill in the relevant art. 

[0087] 

User 1 01 employs user computer 1 00 and analysis applications 1 99 as noted 
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above, including generating and/or accessing some or all of files 212-21 7. As shown 
in Figure 4, files 212-21 7 are maintained in this example on user database server 41 2 
to which user computer 1 00 is coupled via network cable 480. Computers 1 00', 1 00", 
and computers of other users in a local or wide-area network including an Intranet, 
the Internet, or any other network may also be coupled to server 4 1 2 via cable 480. It 
will be understood that cable 400 is merely representative of any type of network 
connectivity, which may involve cables, transmitters, relay stations, network servers, 
and many other components not shown but evident to those of ordinary skill in the 
relevant art. Via user computer 1 00, user 1 01 may operate a web browser served by 
user-side Internet client 410 to communicate via Internet 499 with portal 400. Portal 
400 may similarly be in communication over Internet 499 with other users and/or 
networks of users, as indicated by Internet clients 41 0 1 and 410". 

[0088] 

As previously noted, the information provided by user 1 01 to portal 400 typically 
includes one or more "probe-set identifiers." These probe-set identifiers typically 
come to the attention of user 101 as a result of experiments conducted on probe 
arrays. For example, user 1 01 may select probe-set identifiers that identify microarray 
probe sets capable of enabling detection of the expression of mRNA transcripts from 
corresponding genes or ESTs of particular interest. As is well known in the relevant 
art, an EST is a fragment of a gene sequence that may not be fully characterized, 
whereas a gene sequence generally is complete and fully characterized. The word 
"gene" is used generally herein to refer both to full size genes of known sequence and 
to computationally predicted genes. In some implementations, the specific sequences 
detected by the arrays that represent these genes or ESTs may be referred to as, 
"sequence information fragments (SIF's)"and may be recorded in a "SIF file," as noted 
above with respect to the operations of LIMS 225. In particular implementations, a SIF 
is a portion of a consensus sequence that has been deemed to best represent the 
mRNA transcript from a given gene or EST. The consensus sequence may have been 
derived by comparing and clustering ESTs, and possibly also by comparing the ESTs 
to genomic sequence information. A SIF is a portion of the consensus sequence for 
which probes on the array are specifically designed. With respect to the operations of 
web portal 400, it is assumed with respect to some implementations that some 
microarray probe sets may be designed to detect the expression of genes based upon 
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sequences of EST's. 

[0089] As was described above, the term "probe set" refers in some implementations to 
one or more probes from an array of probes on a microarray. For example, in an 
Affymetrix ® GeneChip ® probe array, in which probes are synthesized on a substrate, 
a probe set may consist of 30 or 40 probes, half of which typically are controls. These 
probes collectively, or in various combinations of some or all of them, are deemed to 
be indicative of the expression of a gene, EST, or protein. In a spotted probe array, 
one or more spots may similarly constitute a "probe set." 

[0090] The term "probe-set identifiers" is used broadly herein in that a number of types 
of such identifiers are possible and are intended to be included within the meaning of 
this term. One type of probe-set identifier is a name, number, or other symbol that is 
assigned for the purpose of identifying a probe set. This name, number, or symbol 
may be arbitrarily assigned to the probe set by, for example, the manufacturer of the 
probe array. A user may select this type of probe-set identifier by, for example, 
highlighting or typing the name. Another type of probe-set identifier as intended 
herein is a graphical representation of a probe set. For example, dots may be 
displayed on a scatter plot or other diagram wherein each dot represents a probe set. 
Typically, the dot's placement on the plot represents the intensity of the signal from 
hybridized, tagged, targets (as described in greater detail below) in one or more 
experiments. In these cases, a user may select a probe-set identifier by clicking on, 
drawing a loop around, or otherwise selecting one or more of the dots. In another 
example, user 1 01 may select a probe-set identifier by selecting a row or column in a 
table or spreadsheet that correlates probe sets with accession numbers and other 
genomic information. 

[0091] Yet another type of probe-set identifier, as that term is used herein, includes a 
nucleotide or amino acid sequence. For example, it is illustratively assumed that a 
particular SIF is a unique sequence of 500 bases that is a portion of a consensus 
sequence or exemplar sequence gleaned from EST and/or genomic sequence 
information. It further is assumed that one or more probe sets are designed to 
represent the SIF. A user who specifies all or part of the 500-base sequence thus may 
be considered to have specified all or some of the corresponding probe sets. 
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[0092] In yet another example, a user may specify a SIF, gene, protein, or EST sequence 
for which there are no corresponding probe sets. The user requests to have a 
corresponding probe set produced for the specified sequence. User-service manager 
522 (described below) assigns an identifier for the new probe set and this identifier, 
together with the sequence or sequences from which the probes are to be designed, 
are stored by database manager 512 in one or more databases. Manager 522 may 
submit and/or design probe sets for the corresponding SIF, gene, or EST and 
correlates the probe sets with the new probe set identifiers. Further details regarding 
the processing and implementation of custom probe designs are provided in U.S. 
Provisional Patent Application, Serial No. 60/301 ,298, titled "WEB APPLICATION FOR 
DESIGNING AND ORDERING FLEXIBLE CONTENT ARRAYS", filed June 25, 2001; U.S. 
Provisional Patent Application Serial No. 60/265,103, titled "RAPID FLEXIBLE CONTENT 
ARRAY AND ONLINE OREDRING SYSTEM", filed January 29, 2001 ; and U.S. Patent 
Application Serial No. 09/824,93 1 , titled "METHOD AND SYSTEM FOR EFFICIENT MASK 
USAGE IN MANUFACTURING DNA ARRAYS", filed April 3, 2001, each of which is hereby 
incorporated by reference herein in its entirety for all purposes. Additional aspects of 
probe design are described below in relation to the operations of probe sequence 
verifier/designer 1 1 20 and other elements of the illustrative implementation of Figure 
11. 

[0093] As a further example with respect to a particular implementation, a user may 

specify a portion of the 500-base sequence noted above, which may be unique to that 
SIF, or, alternatively, may also identify another SIF, EST, cluster of ESTs, consensus 
sequence, and/or gene or protein. The user thus specifies a probe-set identifier for 
one or more genes or ESTs. In another variation, it is illustratively assumed that a 
particular SIF is a portion of a particular consensus sequence. It is further assumed 
that a user specifies a portion of the consensus sequence that is not included in the 
SIF but that is unique to the consensus sequence or the gene or ESTs the consensus 
sequence is intended to represent. In that case, the sequence specified by the user is 
a probe-set identifier that identifies the probe set corresponding to the SIF, even 
though the user-specified sequence is not included in the SIF. Parallel cases are 
possible with respect to user specifications of partial sequences of ESTs and genes or 
ESTs, as those skilled in the relevant art will now appreciate. 
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[0094] 



A further example of a probe-set identifier is an accession number of a gene or 



EST. Gene and EST accession numbers are publicly available. A probe set may 
therefore be identified by the accession number or numbers of one or more ESTs 
and/or genes corresponding to the probe set. The correspondence between a probe 
set and ESTs or genes may be maintained in a suitable database, such as that 
accessed by database application 230 or local library databases 516, from which the 
correspondence may be provided to the user. Similarly, gene fragments or sequences 
other than ESTs may be mapped (e.g., by reference to a suitable database) to 
corresponding genes or ESTs for the purpose of using their publicly available 
accession numbers as probe-set identifiers. For example, a user may be interested in 
product or genomic information related to a particular SIF that is derived from EST-1 
and EST-2. The user may be provided with the correspondence between that SIF (or 
part or all of the sequence of the SIF) and EST-1 or EST-2, or both. To obtain product 
or genomic data related to the SIF, or a partial sequence of it, the user may select the 
accession numbers of EST-1 , EST-2, or both. 

[0095] Additional examples of probe-set identifiers include one or more terms that may 
be associated with the annotation of one or more gene or EST sequences, where the 
gene or EST sequences may be associated with one or more probe sets. For 
convenience, such terms may hereafter be referred to as "annotation terms" and will 
be understood to potentially include, in various implementations, one or more words, 
graphical elements, characters, or other representational forms that provide 
information that typically is biologically relevant to or related to the gene or EST 
sequence. Associations between the probe-set identifier terms and gene or EST 
sequences may be stored in a database such as Probe-set ID to sequence database 
511, local genomic database 51 8, or they may be transferred from remote databases 
402. Examples of such terms associated with annotations include those of molecular 
function (e.g. transcription initiation), cellular location (e.g. nuclear membrane), 
biological process (e.g. immune response), tissue type (e.g. kidney), or other 
annotation terms known to those in the relevant art. 



To provide a further specific example, user 1 01 may input the illustrative 
annotation term "tumor suppression." A large number of genes or ESTs are known to 
be involved with this biological process. For example, a gene known as p53 is involved 
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with tumor suppression, and this information is stored in one or more of the 
databases accessible from database server 41 0. Portal 400 provides to user 1 01 a list 
of probe-set identifiers that includes the one or more probe-set identifiers associated 
with gene p53. The list of probe-set identifiers may be provided to the user in one of 
numerous possible formats. For example, the format may include a table comprising 
ail the probe sets associated with all the genes or EST's associated with "tumor 
suppression." Alternatively, the format may separate the probe sets related to each 
gene or EST into its own table. 

[0097] 

Genomic web portal 400: Genomic web portal 400 provides to user 101 data 
related to one or more genes, ESTs, or proteins. Feature elements that make up a 
gene include: exons, 5' and 3' untranslated regions, coding regions, start and stop 
codons, introns, 5* transcriptional control elements, 3' polyadenylation signals, splice 
site boundaries, and protein-based annotations of the coding regions. In the present 
implementation, an EST or protein may include what those of ordinary skill in the 
related art refer to as alternative splice variants. An alternative splice variant generally 
refers to ESTs or proteins that are derived from a specific composition and 
arrangement of exons, or coding regions, from a genomic DNA sequence or gene. A 
molecular apparatus commonly referred to as the "splicesome" performs a process 
referred to as RNA processing after a gene has been transcribed into a primary RNA 
transcript. The splicesome cleaves the primary RNA transcript at specific locations that 
include the intron/exon boundaries. After cleavage, the splicesome rearranges the 
cleaved sequence and splices the sequence together, generally leaving out the intron 
sequences and possibly leaving out one or more exon sequences. The splicesome may 
produce alternative splice variants by altering the number, arrangement, and/or 
content (i.e., by splicing one or more intron/exon portions) of exons. Thus, alternative 
splice variants could also include the arrangement of partial sequence from exons 
that, for instance, may include alternative 3" and 5" splice sites. Those of ordinary skill 
in the related art will appreciate that approximately a third to over half of all human 
genes produce multiple transcript variants (E. S. Lander, et al., "Initial sequencing and 
analysis of the human genome," Nature, vol. 409, pp. 860-921 ., 2001 ; A. A. Mironov, 
J. W. Fickett, and M. S. Gelfand, "Frequent alternative splicing of human genes," 
Genome Res, vol. 9, pp. 1288-93., 1999), hereby incorporated by reference herein in 
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their entireties. Each alternative splice variant could have different expression patterns 
and function. It is also generally appreciated that alternative splicing is an important 
regulatory mechanism in higher eukaryotes. For example, a gene could include three 
exons that for the purposes of illustration may be referred to as exon 1 , exon 2, and 
exon 3. In the present example, a plurality of alternative splice variants from that gene 
are possible that could include an EST composed of exons 1 , 2, and 3; another EST 
composed of exons 1 , and 2; or an EST composed of 1 , and 3. 

[0098] Typically, each gene or EST has at least one corresponding probe set that is 
identified by a probe-set identifier that, as just noted, may be a number, name, 
accession number, symbol, graphical representation (e.g., dot or highlighted tabular 
entry), or nucleotide sequence, as illustrative and non-limiting examples. The 
corresponding probe sets are capable of enabling detection of the expression of their 
corresponding gene or alternative splice variant. In some embodiments a probe set 
designed to recognize the mRNA expression of a gene may identify one or more 
alternative splice variants. In some cases a plurality of probe sets may be capable of 
identifying a specific alternative splice variant. 

[0099] )n a pre f errec | embodiment, probe sets are designed to identify specific alternative 
splice variants. For example, a probe set may consist of probes designed to 
interrogate the exons of a particular alternative splice variant as well as junction 
probes designed to interrogate the region where two specific exons are predicted to 
be joined together. The junction probe may interrogate, for instance, the sequence of 
the 3" end of exon 1 and the 5" end of exon 3. In the present example, an alternative 
splice variant mRNA that comprises exons 1 and 3 will hybridize to the exon probes 
and, if the splice variant is joined in the correct orientation, it will also hybridize to the 
one or more junction probes. Additional examples of alternative splice variant probe 
sets and probe arrays are described in U.S. Patent Application Serial No. 09/697,877, 
titled "METHODS FOR MONITORING THE EXPRESSION OF ALTERNATIVLEY SPLICED 
GENES", filed October 26, 2000; U.S. Provisional Patent Application Serial No. 
60/362,31 5, titled "ALTERNATIVE SPLICE CHIP", filed March 6, 2002; and U.S. 
Provisional Patent Application Serial No. 60/362,524, titled "METHODS FOR 
DETERMINING A MINIMAL SET OF PROBES FOR ALTERNAITVE SPLICING NUCLEIC ACID 
PROBE ARRAY DESIGN", filed March 6, 2002; each of which is hereby incorporated by 
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reference herein in its entirety for all purposes. 

[01 00] In response to a user selection of one or more probe-set identifiers, portal 400 
provides user 1 01 with one or more of genomic, EST, protein, or annotation 
information and/or information regarding biological products. This information may 
be helpful to user 1 01 in analyzing the results of experiments and in designing or 
implementing follow-up experiments. 

[01 01 ] Figure 5 is a functional block diagram of one of many possible embodiments of 

portal 400. In this example, portal 400 has hardware components including three 
computer platforms: database server 510, Internet server 530, and application server 
520. Various functional elements of portal 400, such as database manager 512, input 
and output managers 532 and 534, and user-service manager 522, carry out their 
operations on these computer platforms. That is, in a typical implementation, the 
functions of managers 512, 532, 534, and 522 are carried out by the execution of 
software applications on and across the computer platforms represented by servers 
510, 530, and 520. Portal 400 is described first with respect to its computer 
platforms, and then with respect to its functional elements. 

[0102] Each of servers 510, 520 and 530 may be any type of known computer platform or 
a type to be developed in the future, although they typically will be of a class of 
computer commonly referred to as servers. However, they may also be a main frame 
computer, a work station, or other computer type. They may be connected via any 
known or future type of cabling or other communication system including wireless 
systems, either networked or otherwise. They may be co-located or they may be 
physically separated. Various operating systems may be employed on any of the 
computer platforms, possibly depending on the type and/or make of computer 
platform chosen. Appropriate operating systems include Windows NT ® , Sun Solaris, 
Linux, OS/400, Compaq Tru64 Unix, SGI IRIX, Siemens Reliant Unix, and others. 

[01 03] There may be significant advantages to carrying out the functions of portal 400 on 
multiple computer platforms in this manner, such as lower costs of deployment, 
database switching, or changes to enterprise applications, and/or more effective 
firewalls. Other configurations, however, are possible. For example, as is well known 
to those of ordinary skill in the relevant art, so-called two-tier or N-tier architectures 
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are possible rather than the three-tier server-side component architecture 
represented by Figure See, for example, E. Roman, Mastering Enterprise JavaBeans ™ 
and the Java ™ 2 Platform ( John Wiley & Sons, Inc., NY, 1 999) and J. Schneider and R. 
Arora, Using Enterprise Java ™ (Que Corporation, Indianapolis, 1997), both of which 
are hereby incorporated by reference in their entireties for all purposes. 

[01 04] It will be understood that many hardware and associated software or firmware 
components that may be implemented in a server-side architecture for Internet 
commerce are not shown in Figure 5. Components to implement one or more firewalls 
to protect data and applications, uninterruptable power supplies, LAN switches, web- 
server routing software, and many other components are not shown. Similarly, a 
variety of computer components customarily included in server-class computing 
platforms, as well as other types of computers, will be understood to be included but 
are not shown. These components include, for example, processors, memory units, 
input/output devices, buses, and other components noted above with respect to user 
computer 1 00. Those of ordinary skill in the art will readily appreciate how these and 
other conventional components may be implemented. 

[01 05] The functional elements of portal 400 also may be implemented in accordance 

with a variety of software facilitators and platforms (although it is not precluded that 
some or all of the functions of portal 400 may also be implemented in hardware or 
firmware). Among the various commercial products available for implementing e- 
commerce web portals are BEA WebLogic from BEA Systems, which is a so-called 
"middleware" application. This and other middleware applications are sometimes 
referred to as "application servers," but are not to be confused with application server 
520, which is a computer. The function of these middleware applications generally is 
to assist other software components (such as managers 512, 522, or 532) to share 
resources and coordinate activities. The goals include making it easier to write, 
maintain, and change the software components; to avoid data bottlenecks; and 
prevent or recover from system failures. Thus, these middleware applications may 
provide load-balancing, fail-over, and fault tolerance, all of which features will be 
appreciated by those of ordinary skill in the relevant art. 

[01 06] 

Other development products, such as the Java ™ 2 platform from Sun 
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Microsystems, Inc. may be employed in portal 400 to provide suites of applications 
programming interfaces (API's) that, among other things, enhance the implementation 
of scalable and secure components. The platform known as J2EE (Java ™ 2, Enterprise 
Edition), is configured for use with Enterprise JavaBeans ™ , both from Sun 
Microsystems. Enterprise JavaBeans ™ generally facilitates the construction of server- 
side components using distributed object applications written in the Java ™ language. 
Thus, in one implementation, the functional elements of portal 400 may be written in 
Java and implemented using J2EE and Enterprise JavaBeans ™ . Various other software 
development approaches or architectures may be used to implement the functional 
elements of portal 400 and their interconnection, as will be appreciated by those of 
ordinary skill in the art. 

[0107] 

One implementation of these platforms and components is shown in Figure 6. 
Figure 6 is a simplified graphical representation of illustrative interactions between 
user-side internet client 41 0 on the user side and input and output managers 532 and 
534 of Internet server 530 on the portal side, as well as communications among the 
three tiers (servers 510, 520, and 530) of portal 400. Browser 605 on client 41 0 sends 
and receives HTML documents 620 to and from server 530. HTML document 625 
includes applet 627. Browser 605, running on user computer 1 00, provides a run- 
time container for applet 627. Functions of managers 532 and 534 on server 530, 
such as the performance of GUI operations, may be implemented by servlet and/or JSP 
640 operating with a Java ™ platform. A servlet engine executing on server 530 
provides a runtime container for servlet 640. JSP Cava Server Pages) from Sun 
Microsystems, Inc. is a script-like environment for GUI operations; an alternative is 
ASP (Active Server Pages) from the Microsoft Corporation. App server 650 is the 
middleware product referred to above, and executes on application server 520. EJB 
(Enterprise JavaBeans ™ ) is a standard that defines an architecture for enterprise 
beans, which are application components. CORBA (Common Object Request Broker 
Architecture) similarly is a standard for distributed object systems, i.e., the CORBA 
standards are implemented by CORBA-compliant products such as Java ™ IDL. An 
example of an EJB-compliant product is WebLogic, referred to above. Further details 
of the implementation of standards, platforms, components, and other elements for 
an Internet portal and its communications with clients, are well known to those skilled 



App_ID= 10065 868 



Page 42 of 109 



Ji O O Jfdi - 7i S3 -r t «, 1 t >P G P a? 

in the relevant art. 

[01 08] As noted, one of the functional elements of portal 400 is input manager 532. 

Manager 532 receives a set, i.e., one or more, of probe-set identifiers from user 101 
over Internet 499. Manager 532 processes and forwards this information to user- 
service manager 522. These functions are performed in accordance with known 
techniques common to the operation of Internet servers, also commonly referred to in 
similar contexts as presentation servers. Another of the functional elements of portal 
400 is output manager 5 34. Manager 534 provides information assembled by user- 
service manager 522 to user 101 over Internet 499, also in accordance with those 
known techniques, aspects of which were described above in relation to Figure 6. The 
information assembled by manager 522 is represented in Figure 5 as data 524, 
labeled "integrated genomic and/or product web pages responsive to user request." 
The data is integrated in the sense, among other things, that it is based, at least in 
part, on the specification by user 1 01 of probe-set identifiers and thus has common 
relationships to the genes and/or ESTs, or proteins corresponding to those 
identifiers. The presentation by manager 5 34 of data 524 may be implemented in 
accordance with a variety of known techniques. As some examples, data 524 may 
include HTML or XML documents, email or other files, or data in other forms. The data 
may include Internet URL addresses so that user 1 01 may retrieve additional HTML, 
XML, or other documents or data from remote sources. 

[0109] Portal 400 further includes database manager 512. In the illustrated embodiment, 
database manager 512 coordinates the storage, maintenance, supplementation, and 
all other transactions from or to any of local databases 511, 513, 514, 516, and 51 8. 
Manager 512 may undertake these functions in cooperation with appropriate database 
applications such as the Oracle • 8.0.5 database management system. 

[01 10] 

In some implementations, manager 512 periodically updates local genomic 
database 518. The data updated in database 518 includes data related to genes, 
ESTs, or proteins that correspond with one or more probe sets. The probe sets may 
be those used or designed for use on any microarray product, and/or that are 
expected or calculated to be used in microarray products of any manufacturer or 
researcher. For example, the probe sets may include all probe sets synthesized on the 



App_II>=10065868 



Page 43 of 109 



line of stocked CeneChip ® probe arrays from Affymetrix, Inc., including its 
Arabidopsis Genome Array, CYP450 Array, Drosophila Genome Array, E. coli Genome 
Array, GenFlex ™ Tag Array, HIV PRT Plus Array, HuGeneFL Array, Human Genome U95 
Set, Human Genome U133 Set, HuSNP Probe Array, Murine Genome U74 Set, P53 
Probe Array, Rat Genome U34 Set, Rat Neurobiology U34 Set, Rat Toxicology U34 
Array, Human Genome Focus Array, or Yeast Genome S98 Array. The probe sets may 
also include those synthesized on alternative splice arrays or custom arrays for user 
101 or others. However, the data updated in database 518 need not be so limited. 
Rather, it may relate to any number of genes, ESTs, or proteins. Types of data that 
may be stored in database 51 8 are described below in relation to the operations of 
manager 522 in directing the periodic collection of this data from remote sources 
providing the locally maintained data in database 51 8 to users. 

[01 1 1] Database 516 includes data of a type referred to above in relation to database 

application 230, i.e., data that associates probe sets with their corresponding gene or 
EST and their identifiers. Database 5 1 6 may also include SIF's, and other library data. 
User-service manager 522 may provide database manager 51 2 from time to time with 
update information regarding library and other data. In some cases, this update 
information will be provided by the owners or managers of proprietary information, 
although this information may also be made available publicly, as on a web site, for 
uploading. 

[01 12] Information for storage by manager 512 in local products database 514 may 
similarly be provided by vendors, distributors, or agents, or obtained from public 
sources such as web sites. A wide variety of product-related information may be 
included in database 514, examples of which include availability, pricing, 
composition, suitability, or ordering data. The information may relate to a wide variety 
of products, including any type of biological device or substance, or any type of 
reagent that may be used with a biological device or substance. To provide just a few 
examples, the device, substance, or reagent may be an oligonucleotide, probe array, 
clone, antibody, or protein. The data stored in database 51 4 may also include links, 
such as Internet URL addresses, to remote sites where product data is available, such 
as vendors" web sites. 
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[01 13] Database 51 1 includes information relating probe-set identifiers to the sequences 
of the probes. This information may be provided by the manufacturer of the probes, 
the researchers who devise probes for spotted arrays or other custom arrays, or 
others. Moreover, the application of portal 400 is not limited to probes arranged in 
arrays. As noted, probes may be immobilized on or in beads, optical fibers, or other 
substrates or media. Thus, database 51 1 may also include information regarding the 
sequences of these probes. 

[01 1 4] Database 5 1 9 includes information about users and their accounts for doing 

business with or through portal 400. Any of a variety of account information, such as 
current orders, past orders, and so on, may be obtained from users, all as will be 
readily apparent to those of ordinary skill in the art. Also, information related to users 
may be developed by recording and/or analyzing the interactions of users with portal 
400, in accordance with known techniques used in e-commerce. For example, user- 
service manager 522 may take note of users" areas of genomic interest, their 
purchase or product-inquiry activities, the frequency of their accessing of various 
services, and so on, and provide this information to database manager 51 2 for 
storage or update in database 51 9. 

[01 1 5] Another functional element of portal 400 is user-service manager 522. Among 
other functions, manager 522 may periodically cause database manager 51 2 to 
update local genomic database 51 8 from various sources, such as remote databases 
402. For example, according to any chronological schedule (e.g., daily, weekly, etc.), 
or need-driven schedule (e.g., in response to a user making an authorized request for 
updated information), manager 522 may, in accordance with known techniques, 
initiate searches of remote databases 402 by formulating appropriate queries, 
addressed to the URL's of the various databases 402, or by other conventional 
techniques for conducting data searches and/or retrieving data or documents over the 
Internet. These search queries and corresponding addresses may be provided in a 
known manner to output manager 534 for presentation to databases 402. Input 
manager 532 receives replies to the queries and provides them to manager 522, 
which then provides them to database manager 512 for updating of database 518, all 
in accordance with any of a variety of known techniques for managing information 
flow to, from, and within an Internet site. 



App_D3=10065868 



Page 45 of 109 



[01 16] Portal application manager 526 manages the administrative aspects of portal 400, 
possibly with the assistance of a middleware product such as an applications server 
product. One of these administrative tasks may be the issuance of periodic 
instructions to manager 522 to initiate the periodic updating of database 518 just 
described. Alternatively, manager 522 may self-initiate this task. It is not required 
that all data in database 51 8 be updated according to the same periodic schedule. 
Rather, it may be typical for different types of data and/or data from different sources 
to be updated according to different schedules. Moreover, these schedules may be 
changed, and need not be according to a consistent schedule. That is, updating for 
particular data may occur after a day, then again after 2 days, then at a different 
period that may continue to vary. Numerous factors may influence the determination 
by manager 526 or manager 522 to maintain or vary these periods, such as the 
response time from various remote databases 402, the value and/or timeliness of the 
information in those databases, cost considerations related to accessing or licensing 
the databases, the quantity of information that must be accessed, and so on. 

[01 1 7] In some implementations, manager 522 constructs from data in local genomic 
database 51 8 a set of data related to genes, EST's, or proteins corresponding to the 
set of probe-set identifiers selected by user 101 . The user selection may be forwarded 
to manager 522 by input manager 532 in accordance with known techniques. 
Manager 522, also in accordance with known techniques, obtains the data from 
database 51 8 by forming appropriate queries, such as in one of the varieties of SQL 
language, based on the user selection. Manager 522 then forwards the queries to 
database manager 5 1 2 for execution against database 5 1 8. Other techniques for 
extracting information from database 51 8 may be used in alternative 
implementations. 

[01 1 8] As notec j > various types of data may be accessed from remote databases 402 and 
maintained in local genomic database 518. Examples are illustrated in figure 1 0 that 
include sequence data 1 01 0, exonic structure or location data 1015, splice-variants 
data 1 020, marker structure or location data 1 025, polymorphism data 1 030, 
homology data 1 035, protein-family classification data 1 040, pathway data 1 045, 
alternative-gene naming data 1050, literature-recitation data 1055, and annotation 
data 1060. Many other examples are possible. Also, genomic data not currently 
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available but that becomes available in the future may be accessed and locally 
maintained as described herein. Examples of remote databases 402 currently suitable 
for accessing in the manner described include GenBank, GenBank New, SwissProt, 
GenPept, DB EST, Unigene, PIR, Prosite, PFAM, Prodom, Blocks, PDB, PDBfinder, EC 
Enzyme, Kegg Pathway, Kegg Ligand, OMIM, OMIM Map, OMIM Allele, DB SNP, Gene 
Ontology, SeqStore ® , PubMed, SWALL, InterPro, and LocusLink. Hundreds of other 
databases currently exist that are suitable, any many more will be developed in the 
future that may be included as aspects of databases 402, and thus this list is merely 
illustrative. 

[01 1 9] Moreover, local genomic database 51 8 may also be supplemented with data 

obtained or deduced (by user-service manager 522) from other of the local databases 
serviced by database manager 512. In particular, although local products database 
514 is shown for convenience of illustration as separate from database 518, it may be 
the same database. Alternatively, or all or part of the data in database 514 may be 
duplicated in, or accessible from, database 51 8. Also, in some implementations, data 
may be retrieved from one or more of remote databases 402 in real time with respect 
to a user request rather than from locally maintained database 518. 

[01 20] More specific examples are now provided of how user service manager 522 may 
receive and respond to requests from user 101 for genomic, EST, protein, or 
annotation information, as well as for product information and/or ordering. These 
examples are described in relation to Figures 7 through 1 5. 

[0121] 

Figures 7A and 7B are flow charts representing illustrative methods by which 
portal 400 may respond to a user's request for genomic information related to 
alternative splice variants, or a request to provide a customized probe array, 
respectively. In accordance with step 71 0 or 750 of these examples, input manager 
532 receives from client 410 over Internet 499 a request by user 1 01 . This request 
may, for instance, include an HTML, XML, or text document (e.g., tab delimited *.txt 
document) that includes user 101's selection of certain probe-set identifiers. As 
noted, the probe-set identifiers may be a number, name, accession number, symbol, 
graphical representation, or nucleotide or other sequence, as non-limiting examples. 
In some cases, user 101 may make this selection by employing one or more of 
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analysis applications 1 99A to select probe-set identifiers (e.g., by drawing a loop 
around dots, selecting portions of a graph or spreadsheet, or other methods as noted 
above) and then activating communication with portal 400 by any of a variety of 
known techniques such as right-clicking a mouse. The request may also, in 
accordance with any of a variety of known techniques, specify that user 1 01 is 
interested in genomic and/or product data, as well as details regarding the type of 
data that is desired. For instance, user 101 may select categories of products, names 
of vendors or products, and so on from pull-down menus. Manager 532 provides user 
1 01 's request to user service manager 522, as described above. 

[0122] In accordance with step 720, user-service manager 522 initiates an identification 
of user 1 01 . Figure 8 is a functional block diagram showing the functional elements of 
manager 522 in greater detail, including account ID determiner 81 0 that, in this 
illustrative implementation, undertakes the task of identifying user 1 01 . Determiner 
810 may employ any of various known techniques to obtain this information, such as 
the use of cookies or the extraction from the user's request of an identification 
number entered by the user. Determiner 810, through database manager 512, may 
compare the user's identification with entries in user account database 519 to further 
identify user 101. In other implementations, the identity of user 1 01 need not be 
obtained, although statistics or information regarding user 101's request may be 
recorded, as noted above. 

[0123] In accordance with step 72 5, user-service manager 522 in one implementation 
formulates an appropriate query (using, for example, a version of the SQL language) 
for correlating probe-set identifiers with corresponding genes, ESTs, or proteins. 
Gene or EST verifier 1 1 1 0 of Gene or EST determiner 820 is the functional element of 
manager 522 that executes this task in the illustrated example. Correlator 1 1 30 
forwards the query to database manager 512. If the probe-set identifiers provided by 
user 1 01 include sequence information, then the query may seek to verify the 
existence of one or more corresponding probe sets, consisting of verified probes, 
from database 511, and/or from SIF information in database 516. If verified, verifier 
1110 correlates the identity of the one or more probe sets having a corresponding 
(e.g., similar in biological significance) sequence with the probe set identifiers. 
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[0124] If the included sequence information does not have a corresponding probe-set, 

such as a case in which user 101 has requested to have a probe-set produced, then 
the included sequence is forwarded to probe sequence verifier/designer 1 1 20. 
Verifier/designer 1 120 performs an analysis of the user-provided input sequence to 
determine which portions of the sequence should be represented by probes. For 
example, some portions of the input sequence may consist of short, common repeats 
that are not effective in uniquely representing the sequence as a whole. Importantly, 
probes representing the input sequence should be unique, either in combination or, 
preferably, individually, with respect to the input sequence. To provide a greater 
statistical likelihood that each probe will be unique, verifier/designer 1 1 20 may 
require that probes be of a minimum standard length (e.g., 25 bases) that typically 
may be predetermined based, e.g., on statistical analysis as applied to genomic 
distributions and various probe-production considerations. However, in some 
implementations, the probe length may be variable above a minimum determined by 
verifier/designer 1 1 20 and may be set by the user, or may be selected by the user 
from a list of permissible options. Verifier/designer 1 1 20 applies various other criteria 
and tests to verify and/or design probe sequences appropriate for representing the 
user-provided sequence. For example, verifier/designer 1 1 20 may select or design 
probes using physical models based upon the thermodynamic properties and 
uniqueness of the sequence. Elements of the physical models may include energetic 
parameters (e.g. free energy change A G) derived from each candidate probe 
sequence, and weight coefficients based upon empirical data. The physical models 
could include linear regression modeling or other statistical methods used for 
modeling data. 

[0125] 

In some implementations, verifier/designer 1 1 20 may also determine that the 
user-provided input sequence is not amenable to representation by probes and 
therefore it will create a report that may be communicated via output manager 534 to 
the user. For example, verifier/designer 1 1 20 may analyze the complexity of the 
user-provided sequence and provide the user with a report including a measure of the 
complexity and a determination that the sequence is insufficiently complex (e.g., it 
includes too many repeats) to be uniquely and/or reliably represented by a probe set. 
Additional details regarding the operation of verifier/designer 1 1 20 in alternative 
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implementations are described in the following U.S. patent applications, which are 
hereby incorporated herein by reference in their entireties for all purposes: Serial No. 
09/71 8,295, titled "METHODS AND COMPUTER SOFTWARE PRODUCTS FOR SELECTING 
NUCLEIC ACID PROBES," filed November 21 , 2000; Serial No. 09/721 ,042, titled 
"METHODS AND COMPUTER SOFTWARE PRODUCTS FOR PREDICTING NUCLEIC ACID 
HYBRIDIZATION AFFINITY," filed November 21 , 2000; Serial No. 09/745,965, titled 
"METHOD AND SOFTWARE PRODUCTS FOR SELECTING PROBES USING DYNAMIC 
PROGRAMMING", filed December 21, 2000; and attorney docket number 3359.3, titled 
"METHOD AND COMPUTER SOFTWARE PRODUCTS FOR DESIGNING NUCLEIC ACID 
ARRAYS". 

[01 26] It is assumed for convenience with respect to the illustrated implementation of 

Figure 1 1 that verifier/designer 1 120 returns the sequence, analysis results, and the 
one or more probe sequences of one or more probe sets to verifier 1110. Verifier 
1110 then formulates an SQL statement specifying the user-provided input sequence, 
the probe sequences designed by verifier/designer 1 1 20 to represent the input 
sequence, related analysis results, and possibly other information such as a probe-set 
identifier for the newly selected probe set. Verifier 1110 directs the SQL statement to 
database manager 5 1 2 in accordance with known techniques so that the information 
is stored in an appropriate one or more databases, such as database 51 8 as 
illustratively shown in Figure 1 1. However, as those of ordinary skill in the related art 
will readily appreciate, there are many other possibilities for routing, processing, 
and/or storing the data. For example, verifier/designer 1 1 20 could formulate an SQL 
statement and forward the sequence and analysis results to manager 512 and/or to 
user data processor 840 to be incorporated into a graphical user interface for 
presentation to a user. In some implementations, the data need not be stored for later 
retrieval but simply prepared for display to the user in response to the user's request. 

[0127] j n some implementations, the probe sequences designed by verifier/designer 

1 1 20 to represent the input sequence may be used as an identifier for an unknown, 
e.g., as yet not provided, probe-set. Also, in some implementations, the probe-set 
identifiers could include one or more terms (e.g. referring to annotation information 
such as "tumor suppressor"). In either case, user service manager 522 may identify the 
genes, ESTs, or proteins from database 51 8, where annotation information is stored 
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with the corresponding genes, EST's, or proteins. If the probe-set identifiers include 
names or numbers (e.g., accession numbers), then the query may seek the identity of 
the probe sets from database 516 that, as noted, includes data that associates names, 
numbers, and other probe-set identifiers with corresponding genes or EST's. User 101 
may also have locally employed database application 230 to obtain this information, 
and included it in the information request in accordance with known techniques. In 
this case, step 72 5 need not be performed. 

[0128] 

In a preferred embodiment, determiner 820 may perform methods for evaluating 
the presence of alternative splice variants in one or more experiments from an input 
set of one or more probe set identifiers and associated hybridization intensities from 
the one or more experiments. The evaluation methods may be performed by 
alternative splice variant evaluator 1 1 30, as illustrated in Figure 1 1 . In one 
implementation, evaluator 1 1 30 may receive an input set of probe set identifiers and 
associated hybridization intensities derived from the results of probe array 
experiments. Evaluator 1130 performs methods of a kind typically referred to by 
those of ordinary skill in the relevant art as "model fitting" to evaluate the probe set 
identifiers and associated hybridization intensities for alternative splice variants. For 
example, evaluator 1 1 30 receives a set of probe set identifiers and the hybridization 
intensities associated with each probe set identifier from a user via input manager 532 
(or this same information may be passed to evaluator 1 1 30 via account ID determiner 
810 as shown alternatively in Figure 8). Evaluator 1 1 30 of this implementation 
formulates a query to database manager 51 2 to retrieve data related to genomic 
structure and protein domains based, at least in part, upon the input probe set 
identifiers. The genomic structure and protein domain data could for instance include 
data stored in exon structure or location data 1 01 5, protein-family classification data 
1040, or splice-variants data 1020. Evaluator 1 130 fits the probe set identifiers and 
associated hybridization data to models of known genomic structure of alternative 
splice variants using, for example, an iterative model-fitting algorithm. For instance, it 
may be illustratively assumed that a pattern of hybridization data strongly indicates 
the presence of exons 1 and 3 because probe sets representing those exons have 
been detected with high intensity values. These data may be taken to indicate that one 
or more splice variants that include exons 1 and 3 are present. The intensity values 
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related to exons 2 and 4 may, of course, also be relevant to this determination and 
may change the determination based on the overall best fit of the data. In the present 
example, each iteration of the algorithm improves the quality of the fit of the data to 
the known models. One such model, for example, is a linear model that assumes a 
normal of distribution of variables. It will be apparent to those of ordinary skill in the 
related art that a variety of different models could be implemented that may also 
include a variety of assumptions regarding the distribution of variables. 

[0129] 

The fit may, in some implementations, be verified using the protein domain data. 
For example, evaluator 1130 may verify a fit of the probe set identifier and 
hybridization intensity data to a model of a particular splice variant by comparing the 
known function of that splice variant (assuming that there is a known function) to the 
collective properties of the combined functional domains identified by the data. For 
instance, the data may identify one or more DNA binding domains that relate to 
promoter region of a specific gene. Evaluator 1 1 30 may have fit the data to a model of 
an alternative splice variant that has a known function as a transcription factor of the 
same gene. In the present example, evaluator 1 1 30 verifies that there is an accurate 
fit of the data to the model. Additional examples of model fitting and evaluation of 
alternative splice variants are provided in U.S. Patent Application Serial No. 
09/697,877, filed October 26, 2000; U.S. Provisional Patent Application Serial No. 
60/362,315, filed March 6, 2002; and U.S. Provisional Patent Application Serial No. 
60/362,524, filed March 6, 2002, incorporated by reference above, and U.S. 
Provisional Patent Application serial No. 60/362,454, titled "METHODS OF ANALYZING 
HYBRIDIZATION INTENSITIES", filed March 6, 2002; U.S. Provisional Patent Application 
Serial No. 60/362,455, titled "DATABASE STRUCTURE USEFUL FOR ALTERNATIVE 
SPLICING ANALYSIS", filed March 6, 2002; U.S. Provisional Patent Application Serial No. 
60/362,399, titled "ALTERNATIVE SPLICING DETECTION ON UNIVERSAL TAG ARRAY 
USING CAPTURE PROBES TARGETED TO DIFFERENT EXONS AND JUNCTIONS", filed 
March 6, 2002; U.S. Provisional Patent Application Serial No. 60/375,351, titled 
"METHOD AND COMPUTER SOFTWARE PRODUCT FOR PROTEIN BASED ANALYSIS OF 
ALTERNATIVE TRANSCRIPT STRUCTURE", filed April 24, 2002; U.S. Provisional Patent 
Application Serial No. 60/384,552, titled "ALTERNATIVE SPLICING DETECTION", filed 
May 30, 2002; U.S. Provisional Patent Application Serial No. 60/398,958, titled 
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"METHOD OF ANALYZING ALTERNATIVE SPLICING", filed July 26, 2002; and U.S. 
Provisional Patent Application Attorney Docket No. 3508.1, titled "METHOD OF 
ANALYZING ALTERNATIVE SPLICING", filed October 29, 2002, each of which is hereby 
incorporated by reference herein in its entirety for all purposes. 

[01 30] In the same or alternative implementation, a user may input a set of one or more 
probe set identifiers for the purpose of identifying associated alternative splice 
variants so that the user may design an experiment that may be intended, for 
example, to confirm that the splice variants are present. For example, evaluator 1 1 30 
may formulate a query to database manager 51 2 to determine alternative splice 
variants that are known to correspond to the input set of one or more probe set 
identifiers provided by the user. Manager 512 retrieves the alternative splice variant 
data from splice variants data 1 020 of local genomic and/or product database 5 1 8, or 
from other databases located locally or remotely. Evaluator 1 1 30 produces alternative 
splice variant data 1135 from the set of one or more probe set identifiers and the data 
retrieved by manager 512 and/or the results from the model fitting methods. 
Evaluator 1 1 30 then forwards alternative splice variant data 1 1 35 to correlator 830. 

[01 31] As indicated in step 730, user-service manager 522 may then correlate the 

alternative splice variant data 113 5 with the parent gene of each alternative splice 
variant. Additionally, manager 522 may correlate the indicated genes, ESTs, and/or 
proteins with genomic, expression, or annotation information as well as product 
information. 

[0132] 

In one of many possible implementations, correlator 830 of manager 522 may 
undertake this task by formulating a query via database manager 51 2 to database 513 
in order to obtain links to appropriate information in local products database 514 
and/or local genomic database 518. Figure 9 is a simplified graphical representation 
of database 5 1 3. Those of ordinary skill in the art will appreciate that this 
representation is provided for purposes of clarity of illustration, and that many other 
implementations are possible. In one aspect of an appropriate query to database 513, 
which is assumed for illustration to be a relational database, a gene or EST accession 
number 902 is associated with a link 904 to probe-set ID's 91 2. As indicated in Figure 
9 by the association of both ID 902A and 902B to the same link 904N, multiple genes 
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and/or ESTs may be associated with the same probe-set ID. The information used to 
establish these associations is similar to that provided in database 516, as noted 
above, and the links may thus be predetermined or dynamically determined using 
database 5 1 6. 



EST identifiers, such as accession numbers, with products, such as biological 
products. These implementations are indicated in Figure 8 by the arrow directly from 
determiner 81 0 (which is optional) directly to correlator 830. The correlation may be 
accomplished according to any of a variety of conventional techniques, such as by 
providing a query to local products database 514, remote pages 404, and/or remote 
databases 402. These queries may be indexed or keyed by categories, types, names, 
or vendors of products, such as may be appropriate, for example, in examining look- 
up tables, relational databases, or other data structures. In addition, the query may, in 
accordance with techniques known to those of ordinary skill in the relevant art, search 
for products, product web pages, or other product data sources that are logically or 
syntactically associated with the gene or EST identifier(s). The results of the query may 
then be provided by output manager 534 to user 101 , such as over Internet 499 to 
client 410. For example, the genes, ESTs, and/or proteins may include biological 
sequence information that correlator 830 may correlate with product information that 
could include probes, probe sets, and/or probe arrays; reagents; instruments for 
sample preparation, hybridization, incubation, array manufacture, or scanning/signal 
detection; and so on. In the present example, correlator 830 may determine that there 
is no product information associated with a biological sequence. Correlator 830 may 
then return that information to the user via output manager 534 where the user may 
select the biological sequence for probe set verification and design. Alternatively, 
correlator 830 may automatically implement the process of sequence verification and 
probe set design based using the biological sequence. Illustrative methods of 
sequence analysis for probe set verification and design are described in greater detail 
below. 

A further implementation of correlator 830 is illustrated in figure 12, wherein 
cluster correlator 1200 receives from gene or EST determiner 820 a nucleotide 
sequence that may or may not correspond to a probe set. Cluster correlator then 



[0133] 



In other implementations, correlator 830 simply correlates one or more gene or 
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correlates the nucleotide sequence via database manager 5 1 2 with the corresponding 
protein sequence found in gene or EST to protein sequence data 1097, as is illustrated 
in figure 1 0. Alternatively, correlator 1 200 may translate the nucleotide sequence into 
a protein sequence by methods known to those of .ordinary skill in the art. Cluster 
correlator 1 200 then sends the protein sequence to data storage and correlated data 
generators 1 210, 1 21 5, 1220, 1225, 1230, 1235, and 1240. The data storage and 
correlated data generators correspond to databases, now available or that may be 
developed in the future, that contain information regarding associated protein family, 
pathway, network, complex, and/or other protein annotation information. Such 
databases include but are not limited to, SCOP, Pfam, BLOCKS, EC, and GPCR, which 
are known to those in the art as databases that contain annotation information. Such 
clusters of data may be stored in local genomic and/or product database 5 1 8 as 
illustrated in figure 1 0 as clustering data 1 065, 1 070, 1 075, 1 080, 1 085, 1 090, and 
1095. The databases used in this example are for illustration only, and those of 
ordinary skill in the art know that many other examples are possible. 

[013 5] 

The data storage and correlated data generators use methods, known to those in 
the art as clustering methods, to determine sequence or structural similarity and 
alignments with similar protein sequences and/or structures. There are numerous 
types of clustering methods used for these purposes, for example what is commonly 
known as BLASTp represented in figures 1 0 and 1 2 as BLASTp clustering data 1 085 
and BLASTp data storage and correlated data generator 1 230. Another example is 
commonly referred to as the Hidden Markov Model (referred to hereafter as HMM). 
HMM's are pattern matching algorithms that use a training set of data to "learn" the 
patterns contained in that training set of data. A preferred implementation is the so- 
called GRAPA set of HMM's that in the illustrated example are trained to be specific to 
families of proteins where each family has its own HMM trained to its characteristic 
pattern. A trained HMM can then analyze a sequence and return a score that 
corresponds to how well the sequence matches the pattern. In one illustrative 
implementation, a threshold value is assigned so that a score above the threshold is 
considered to be a member of the family and a score below is not. The data storage 
and correlated data generators of this implementation then generate what is 
commonly referred to as a pairwise alignment between the query sequence and the 
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family consensus sequence, and correlate annotation data corresponding to the 
family. 

[01 36] Another function of correlator 830 pertains to a user's desire to have a probe 

array designed from an input set of one or more probe set identifiers. The functional 
element of correlator 830 that performs this task in the illustrated implementation is 
probe array generator 12 50. Generator 1250 receives the set of one or more probe set 
identifiers and/or the one or more probe sets designed by verifier/designer 1 120 
from determiner 820. Generator 1 250 then produces a probe array design based, at 
least in part, upon the input set of one or more probe set identifiers and/or one or 
more designed probe sets, as well as probe array parameters that could include, for 
instance, a template or other parameter that could be stored in one or more 
databases. Generator 1250 of the illustrated implementation assigns a probe array 
identifier to the designed probe array and forwards that probe array design and 
associated identifier to database manager 5 1 2 for storage in one or more databases 
that may include local products database 514. Additionally, generator 1250 may 
forward the probe array design and probe array identifier to user data processor 840 
for incorporation into one or more graphical user interfaces. Additional examples 
regarding the processing and implementation of custom probe array designs are 
provided in U.S. Provisional Patent Application, Serial No. 60/301,298, U.S. Provisional 
Patent Application Serial No. 60/265,103; and U.S. Patent Application Serial No. 
09/824,931, incorporated by reference above. 

[01 37] Figure 7B is a flow chart depicting an illustrative example of receiving a user 

request for the custom design of probe sets and/or probe arrays. It will be understood 
that in Figure 7B, as in Figure 7A, the particular steps and decision elements, and the 
sequence and flow indicated among them, are provided as non-limiting examples and 
that many variations are possible. A graphic example of a web page for executing the 
user request illustrated in Figure 7B is presented in Figure 14 as GUI 1400. In 
accordance with step 750, a user initiates a request by inputting one or more probe 
set identifiers and a selection of probe array format. Alternatively, a default probe 
array format may be automatically selected. A user may initially name a custom design 
probe set or probe array by typing or pasting a selected name into user selectable 
name input field 1 41 0. A user may search for probe set identifiers by selecting probe 
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set identifier search button 1420 that could, for example, provide a separate window 
or pane that displays a list of probe sets or alternatively a list of lists of probe sets 
where a user may make additional selections to refine the search. Additionally, a user 
may upload a set of one or more probe set identifiers by selecting probe set identifier 
upload button 1 425 that could provide the user with an additional window or pane 
requesting additional information such as the location of file to upload. A user may 
also input a sequence by pasting or typing sequence information into user selected 
sequence input field 1 430. The input sequence could be input in a variety of formats 
including FASTA or other type of format. The user may select a format by typing or 
pasting array format information into user selectable description input field 1405. In 
some implementations the format may include a variety of probe array format factors 
that could be user definable from the input information. Alternatively a user may input 
a format identifier into field 1405 to select a predetermined format. In a preferred 
implementation, the probe array format factors include any one or any combination of 
the number of probe sets; a shape and/or one or more dimensions of a probe; one or 
more dimensions of active and/or inactive areas of the probe array; one or more 
indicators of geographic dispersion of probe sets on the probe array; nominal, 
maximum and/or minimum number of probes and/or probes in a probe set 
representing one or more EST, gene, splice variant of a gene, or protein; substrate 
material or design; and/or design of a hybridization chamber or microfluidics body 
encompassing and/or associated with the probe array.. Additionally, the geographic 
dispersion of probe sets on the probe array may be defined by the format. The term 
"geographic dispersion" as used herein refers to the distribution of multiple copies of 
each probe set across a probe array where the probe sets may, for example, be evenly 
distributed throughout the probe array. In the same or other preferred embodiment, 
an even distribution of probe sets may provide a user a degree of protection from a 
variety of experimental factors that could be detrimental to experimental results. 
Some of the experimental factors include damage to one or more regions of the probe 
array or scanner instrument non-linearity. Additionally, an even, or other, distribution 
of multiple copies of each probe set provides a user with redundancy that may be 
used in statistical calculations that include accurate confidence levels in the data set. 

[0138] 

The user submits the selections and/or input information when the user selection 
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submission button 1440 is selected. In accordance with step 750 of Figure 7B, the 
user selections and/or input information is received by gene or EST verifier 1110 and 
processed as described above. 

[01 39] In accordance with step 75 5, the user is identified as previously described in 

relation to step 720 of Figure 7A. Decision element 757 illustrates whether the user 
has input a biological sequence for probe set design. In the case in which a user has 
input a sequence, the sequence is processed in accordance with step 760 by verifying 
and identifying suitable sequence sites for probe set design as previously described in 
relation to probe sequence verifier/designer 1 1 20. As illustrated by decision element 
763, if sequence sites are verified as suitable for probe set design, then 
verifier/designer 1 1 20 may design probe sets to the identified suitable sites in 
accordance with step 765. Alternatively, if there are no verified sites suitable for probe 
array design then verifier/designer 1 1 20 provides an explanation to the user that 
could include a GUI. The GUI could include elements of GUI 1 500 such as field 1 520 to 
display a text message, and/or elements of GUI 1 400 such as input field 1 430 to 
prompt the user to input an additional sequence selection as illustrated in Figure 7B 
as the arrow from step 764 to step 750. 

[0140] In the event that user has input one or more probe set identifiers for incorporation 
into a custom probe array, as illustrated by the negative path of decision element 757, 
then verifier 1110 verifies and correlates the one or more probe set identifiers with 
their associated probe sets in accordance with step 770. Verifier 1110 verifies that 
one or more probes of one or more probe sets exists corresponding to each of the 
one or more probe set identifiers and subsequently correlates each verified probe set 
with its associated probe set identifier. It will be understood that, in alternative 
implementations, other methods may be used to enable the user to specify the type, 
content, arrangement, and other aspects of the probes of a probe array and that the 
use of either a sequence path or probe set identifier path in this example is illustrative 
only. 

[0141] 

In accordance with step 780, probe array generator 12 50 generates the custom 
probe array design, as previously described, from the associated probe sets and probe 
array format information. In accordance with step 790, user data processor 840 
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receives the custom probe array design and/or the custom probe set designs, as well 
as any associated information and generates a graphical user interface (GUI) as 
illustrated in Figure 1 5 as GUI 1 500. GUI 1 500 is illustrative and non-limiting as to 
graphical elements that may be enabled for display by a user using conventional 
methods for formatting and transmitting such information. It is understood that 
numerous alternative arrangements and choices of graphical elements are possible. 
GUI 1 500 is enabled to display associated data received by processor 840, such as 
custom probe array information displayed in custom probe array display field 1510, 
custom probe set designs displayed in custom probe set display filed 1 520, and 
production information display field 1 530. Information displayed in illustrative field 
1510 may include a list or list of lists of probe set identifiers, probe array format, date 
of submission, probe array name, submitter, or other information. 

[0142] 

In some implementations, field 1510 may include names of catalog arrays, i.e., 
arrays previously designed and/or manufactured and stocked for shipment, that 
include an indicated subset (i.e., an indicated percentage and/or list) of the probe sets 
of interest to the user. For example, in response to a user's request for design of 
probe sets or probe arrays corresponding to user-selected probe set identifiers, gene 
or EST verifier 1110 determines verified probe sets, as described above. Gene or EST 
verifier 1110 may also send a query to database manager 51 2 to determine which of 
the verified probe sets already exist on catalog arrays, a database of which may be 
included in local products database 514. Database manager 512 may send 
information specifying the identified catalog array or arrays to user data processor 
840 that may then enable presentation of this information to the user via an 
appropriate graphical user interface. Thus, for example, the user may be notified by 
entries in custom probe array display field 1 510 that specified probe sets responsive 
to the user's request are already included in specified catalog arrays. The user may 
select the identified catalog array and, for example, also select accept button 1 540 to 
indicate a desire to order the selected catalog array. In the manner described below, 
shipping, price, and other information related to the ordering and shipment of the 
catalog array may be displayed to the user in production information display field 
1 530. One of many examples of catalog arrays is the Human Genome Ul 33 Set 
available from Affymetrix, Inc. Other catalog arrays from Affymetrix are listed, as of 
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November 2002, at http://vvww.affymetrix.com/products/arrays/index.affx. A custom 
array may become a catalog array such as, for example, when a user consents that the 
custom array be made available to other users. Similarly a custom array may become a 
made-to-order array, which is an array that, like a catalog array, typically is listed for 
general sale but, unlike a catalog array, typically is not stocked for rapid shipment and 
instead is made to order. 

[0143] Even if user 101 orders a catalog array that provides most of the probe sets of 
interest, the user may decide that it is important to also obtain a custom array 
including the remaining probe sets of interest (or, of course, decide to obtain a 
custom array with all of the probe sets of interest). In a case in which user 1 01 
decides to order a custom array having a subset or all of the probe sets of interest, an 
option in some implementations is to enable the user to order a "shared" probe array 
that is shared with other users. For example, it is assumed for purposes of illustration 
only that a custom probe array may be designed for manufacture at a certain price 
and/or for delivery at a certain schedule with up to 5,000 unique probe sets, which 
may be referred to as an example of a nominal custom probe set size. A graphical 
element, such as shared probe array availability field 1435 of GUI 1400, may indicate 
to user 1 01 that 4,520 of the 5,000 nominal probe set locations on a newly designed 
custom array have been sold to, or otherwise reserved for, other users. If user 1 01 
requires 480 or fewer probe sets in a custom array, user 1 01 may then, for example, 
select the shared probe array (or arrays) indicated in field 143 5 and select submit 
button 1440, thereby indicating a desire to have the 480 or fewer probe sets included 
in the selected shared probe array. Optionally, user 101 may select both the shared 
probe array in field 1435 and one or more of the probe sets specified in field 1430 
(prior to verification) and/or field 1 520 (subsequent to verification) in order to 
indicate that only the specified probe sets should be included in the shared probe 
array. It will be understood that various other methods may be employed in alternative 
implementations to enable user 101 to specify probe sets that are to be manufactured 
on one or more probe arrays, some or all of which also contain probe sets 
manufactured for other users. 

[01 44] | n some implementations, a range of probe sets from and including the nominal 
custom probe set size to a smaller number may trigger production and delivery of the 
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custom array as, for example, if user 1 01 places an order for 450 probe sets in the 
instant example. Thus, the "production range of probe sets" for a custom array may 
be a single value (e.g., the nominal custom probe set size) or a range including a 
somewhat smaller number of probe sets. User 1 01 may be informed of this 
production range when placing the order, or elements of user-service manager 522 
(e.g., account data processor 846) may indicate completion of an order for a shared 
custom array when a total number of orders for probe sets enters the range, with or 
without informing user 101 of the existence of the range. Thus, a shared probe array 
may be deemed complete, and ready for production, even though the actual number 
of probe sets ordered falls short of the nominal custom probe set size. In processing 
user orders, user-service manager 522 updates an appropriate database in, e.g., local 
products database 514, to keep track of orders received from various users for probe 
sets. This operation typically is carried out in cooperation with database manager 512 
as noted above. In some implementations, orders for probe sets may be segregated 
based on various types of probe arrays optimized, or otherwise specially configured, 
for the particular type of probe sets ordered by the user (e.g., probe sets for gene 
expression may be produced on arrays of a type different than arrays for genotyping 
or diagnostics, although such differentiation need not be required in various 
implementations). Any of a variety of systems (hereafter sometimes referred to as 
"delivery systems") may be used to implement delivery and order-fulfillment 
operations in accordance with techniques for implementing e-commerce, non-limiting 
examples of which are described in U.S. Provisional Patent Application No. 
60/301,298, incorporated by reference above. Similarly, a variety of systems 
(hereafter sometimes referred to as "production systems") may be used to produce 
arrays by, for example, photolithographic techniques as noted above, and also 
including methods involving direct write optical lithography as described, e.g., in U.S. 
Patent No. 6,480,324, which is hereby incorporated herein in its entirety for all 
purposes. It may therefore be stated herein that genomic web portal 400 of the 
illustrated implementation may "enable" the user to be provided with probe sets on 
shared custom arrays (or with catalog arrays in shared lots as described below) by, 
e.g., providing a production and/or delivery system with the information needed to 
effectuate production and/or delivery. Alternatively, some implementations may 
comprise a business entity or other organization or entity, or collection thereof, that 
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includes not just the genomic web portal, but also the production and/or delivery 
operations and facilities. 

[0145] 

In a similar manner, user 1 01 may share the ordering of a catalog array with other 
users. For example, prices for probe arrays may be conveniently established in terms 
of nominal lot size purchases. That is, for example, the purchase of probe array type 
A in a lot of 200 may cost more than the purchase of the same type A in a lot of 1 ,000 
probe arrays. User 101 may be notified in a graphical element, such as shared probe 
array availability field 1435, that a probe array of interest to user 101 (as indicated by 
user 1 01 by submitting an array name or identifier in field 1410 and/or description in 
field 1405, or as indicated in field 143 5 based on a user's submission of probe set 
identifiers) is subject to a lot-sharing arrangement. In such an arrangement, a 
plurality of users may benefit from sharing a whole-lot order so as to benefit from 
economies of scale. Thus, for example, user 1 01 may indicate (e.g., in field 1 435) that 
he or she wishes to purchase 200 type A probe arrays, but is willing to wait until a 
complete lot of 1 ,000 type A probe arrays is completed based on the orders of 
additional users. The graphical user interface may inform user 101 that unfulfilled 
orders for 700 type A probe arrays have previously been received and thus an order of 
up to 300 additional type A probe arrays may be accommodated within the pending 
lot. In some implementations, a range of ordered probe arrays from and including the 
nominal lot size to a smaller number may trigger production and delivery of the lot as, 
for example, if user 1 01 places an order for 2 50 type A probe arrays, thereby bringing 
the total to 950 of a nominal 1000 array lot. Thus, the "production-lot range" may be 
a single value (e.g., the nominal lot size) or a range including lots of a somewhat 
lesser size (e.g., a range from 950 to 1,000 probe arrays). User 101 may be informed 
of this production-lot range when placing the order, or elements of user-service 
manager 522 (e.g., account data processor 846) may indicate completion of a lot 
when a total number of orders enters the range, with or without informing user 1 01 of 
the existence of the range. Thus, a lot may be deemed complete, and thus priced at 
the rate for the nominal size lot, even though the actual number of orders falls short 
of the nominal lot size. Of course, user 1 01 may order a number of type A probes 
that, alone or together with other unfulfilled orders, exceeds the nominal lot size. In 
this case, additional lots may be produced, the size of the lot may be increased and 
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thus result in lower costs for user 101 and the other users who have ordered the 
probe array, or other arrangements may be made. Alternatively, the completed lot 
may be produced and another pending lot may be created. Thus, in these various 
implementations, user 101 (and the other users who share the lot) generally may 
benefit from the lower price corresponding to the larger nominal lot size. 

[01 46] In yet another implementation, user 1 01 may indicate (e.g., in field 1410) that the 
user is willing to wait a specified period for the lot to be completed, but withdraws the 
offer to buy a portion of the lot after a specified date or time. As one of numerous 
other variations of the shared-ordering option, user 1 01 may specify that the 200 
type A probe arrays should be manufactured on or after a specified date and that user 
1 01 is willing to accept the price at that date based on the number of accumulated 
orders for type A probe arrays from user 1 01 and other users. In yet other 
implementations, user 1 01 may specify a price (and/or other term of purchase or 
delivery), i.e., make a bid as in an auction, that user 1 01 is willing to undertake. Thus, 
for example, user 1 01 may specify a willingness to purchase 200 type A probe arrays 
at a price no greater than X dollars (and possibly also specify that delivery shall occur 
no later than Y date). If the number of users indicating an interest in purchasing type 
A probe arrays increases to a level such that economies of scale, or other 
considerations, result in a lot price for type A probe arrays of X dollars or less, then 
the order is executed in accordance with conventional techniques for conducting e- 
commerce (assuming delivery or other terms, if any, also are satisfied). Also, database 
manager 5 1 2 may periodically consult local product database 5 1 4 to see if nominal 
sale prices or lot sizes of probe array type A have been changed so that user 1 01 's 
order may be accepted even though the lot size, maximum user-specified price, or 
other term, had not been met with respect to the original sales price or lot size. In 
such a manner, discounts, special offers, rewards programs, and so on may be 
implemented to encourage and efficiently effectuate sales of type A probe arrays. 

[01 47] | n Qne 0 f man y possible implementations consistent with various conventional 
techniques for conducting e-commerce, user-service manager 522 generates 
production instructions for type A probe arrays to effectuate orders in accordance 
with any of the preceding, or other, ordering techniques. In some implementations, 
manager 522 provides the production instructions, e.g., via output manager 5 34, to a 
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production unit, e.g., one or more of remote vendor business systems and business 
servers 404. Also in accordance with conventional e-commerce techniques familiar to 
those of ordinary skill in the relevant art, the type A probe arrays may be shipped 
directly from one or more businesses corresponding to business servers 404 to user 
101 and the other users sharing the production lot, or the probe arrays may be 
shipped via intermediaries. In some implementations, a business operating genomic 
portal 400 may undertake production and/or shipping responsibilities, and in some of 
these implementations servers 404 may be local to portal 400 rather than remote. 
Further in accordance with conventional e-commerce techniques (or those that may 
be developed in the future), user-service manager 522 typically records when orders 
have been fulfilled or various stages of fulfillment reached (e.g., at time of production, 
shipping, receipt, and so on). 

[01 48] Returning to the description of Figure 1 5 and the presentation of information to 

user 1 01 , illustrative field 1 520 may display information including the submitted 
reference sequence, verified probe set sites, probe set design sequences, date of 
submission, submitter, or other related information. Illustrative field 1 530 may 
contain detailed production information that includes production schedules, shipping 
schedules, pricing information, or other type of information related to production and 
delivery of custom probe sets or custom probe arrays. Fields 1510, 1 520 or 1 530, or 
various elements displayed in them, may be combined or separately displayed in 
numerous configurations. GUI 1 500 is presented to the user via a network so that, in 
some implementations, the user may select to accept or reject the custom probe array 
design and/or the custom sets designs according to decision element 745. If the user 
reject any or all of the designs by selecting reject design submission button 1 550, GUI 
1400 may be displayed so that the user may elect to re-input information according 
to step 750. GUI 1400 in alternative implementations may include explanations of why 
a user-input sequence, or selection of probe set identifiers, were not included in the 
design of a probe array. If the user accepts a valid design, the use may select accept 
design submission button 1 540 to accept the designs that may then be processed as 
a customer order, as described further below. 

[0149] An additional implementation of correlator 830 includes receiving alternative 
splice variant data 1135 from determiner 820. Data 1 1 35 is illustratively shown as 
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received and processed by alternative splice variant data storage and annotation data 
correlator 1 260. Correlator 1 260 formulates a query to database manger 5 1 2 to find 
genomic structure and protein domain information, based at least in part upon data 
1135. In some implementations, for example, correlator 1 260 in this manner retrieves 
information that includes genomic structural domains, functional protein domains, 
and translation frame for each alternative splice variant contained in data 1135. 
Correlator 1260 also, in some implementations, may determine the overall putative 
function of each alternative splice variant, based at least in part upon the composition 
of the genomic structural domains, the functional protein domains, and the 
translation frame. For example, correlator 1260 may accomplish this function by 
identifying particular regions of genomic structure, such as for instance a 
characteristic seven transmembrane domains, and/or the functional protein domains, 
such as one or more receptor domains. In the present example, the alternative splice 
variant may be identified as a cell surface receptor by the presence of the seven 
transmembrane and one or more receptor domains. Correlator 1260 may forward data 
1135, genomic structural domain, functional protein domain, and putative function 
domain to database manager 512 for storage in one or more databases, as well as to 
user data processor 840 for incorporation into one or more graphical user interfaces 
for presentation to a user. 

[01 50] 

Figures 1 3A and 13B are representations of illustrative examples of graphical user 
interfaces providing user 101 with information obtained by evaluating one or more 
probe set identifiers for alternative splice variants. It will be appreciated by those of 
ordinary skill in the relevant art that numerous alternative formats, both textual and 
graphical, may be used in other implementations. Figure 1 3A illustrates GUI 1 300 that 
includes a variety of individual panes. It will be understood that the illustrated 
combination of panes is non-limiting and that, in various implementations, the panes 
may be otherwise combined or separately displayed by themselves (i.e., in a single 
graphical user interface). Also, not all of the panes need be displayed or available in 
all implementations. In the illustrated example, gene data pane 1302 presents 
information relating to the gene from which the alternative splice variants are derived. 
Such information could include gene name, protein name, accession numbers, protein 
ID numbers, splice variants ID's, numbers of variants, variant function, as well as other 
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related genomic and/or experimental information. In some implementations, pane 
1 302 may display information related specifically to a splice variant selected by the 
user. This selection may include, for example, selection of an exon or region in panes 
1 305, 1 325, or 1335 (described below) by pointing of a mouse or other technique, by 
selection of a probe set identifier corresponding to the splice variant, by providing a 
sequence of interest, and by other methods. The information in pane 1 302 may 
include links to local and/or remote databases or resources such as, for example, by 
hyperlink to genomic information over the Internet. 

[01 51] Full view pane 1 305 displays full length gene 1 307 as a scale of the number of 
bases, where the exon regions of alternative splice variants are aligned along the 
scale. The gene represented in this manner may have been selected by a user in 
accordance with any of the techniques noted herein. In this implementation, each 
variant is distinguished from the others by displaying the variant along a separate 
horizontal line, i.e., by separating the variants vertically in pane 1 305. However, it will 
be understood that many other graphical arrangements or devices known to those of 
skill in the art may be used to distinguish splice variants and/or distinguish exons 
belonging to one or more splice variants. For example, the variants and/or their exons 
may be color-coded, identified by differently shaped objects, and so on. 

[01 52] A user may wish to view a particular splice variant, or a particular region of a 

splice variant, in greater detail. In one example of how the user may indicate this wish, 
the user may select boxed region 1 309 by, for example, dragging a mouse along the 
horizontal representation of the bottom horizontal display of exons in pane 1305 that 
represents the arrangement of exons in a particular splice variant. Alternatively, the 
user could click on the start and end of the desired region, enter a chromosomal 
location as may in some implementations be indicated by the scale at the bottom of 
pane 1 305, enter a location relative to the beginning of the gene or relative to another 
marker like a SNP site, enter a sequence to specify a start and/or stop area, and so on. 
The resulting expanded view of boxed region 1 309 is displayed as boxed region 1 308 
in intermediate view pane 1 325. 

[0153] 

In addition to providing an expanded view of a user-selected splice variant or 
portion thereof, intermediate view pane 1325 in the illustrated example displays 
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additional alternative splice variants aligned to one another and to a full length 
reference sequence. Displayed in both full view pane 1305 and intermediate view pane 
1 325 are start site 1 326 and stop site 1 327. Site 1 326 may indicate the start site of 
transcription and/or translation and site 1327 may represent the site of termination of 
transcription and/or translation. Also displayed in pane 1 325 is exon probe set sites 
1 340 and junction probe set sites 1 345 that are illustrative examples of probe set 
annotations. Sites 1340 represent the regions of exons that are interrogated by probe 
sets, and similarly sites 1 345 displays the relationship of probe sets that interrogate 
the junction region where two exons may be spliced together. In the illustrated 
implementation, each of the displayed boxes of sites 1 340 may represent a single 
probe set whereas each of the displayed boxes of sites 1345 may represent a portion 
of a probe set that may, for instance, include a box representing half a probe set that 
interrogates the sequence region at the end of one exon (e.g., the 5" end) and another 
box representing the remaining half of the probe set may interrogate the sequence at 
the end of another exon (e.g., the 3" end). In some implementations it is not 
necessary that adjacent boxes of sites 1 345 belong to the same probe set, rather each 
box may be representative of some portion of a probe set that may be used in 
combination with a box belonging to sites 1 345 representing a complementary 
portion. For example, a box belonging to sites 1 345 at the 5" end of exon one may 
represent a portion of a probe set that could, for instance, be half the number of 
probes of a probe set. A complimentary box could be located at the 3" end of exon 
two, three, or the 3" end of any exon contained within a particular gene that contains 
the remaining portion of a probe set that identifies a splice variant containing exon 
one spliced to exon two, three, or other exon defined by the probe set. 

[0154] 

The relative abundance of alternative splice variants may also be displayed in 
panes 1 305 and 1 325. Methods for representing abundance may include color coding 
of exon bars 1 303, variations in exon bar height, variations in exon bar pattern, or 
other graphical methods commonly used to distinguish differences. The measure of 
abundance could include the relative expression level of each alternative splice 
variant, the frequency of exon usage in all alternative splice variants, or other user- 
selected measure. For example, illustrated in Figure 1 3B is GUI 1350 that includes 
reference exon bar 1 365. A user may cause GUI 1 350 to be displayed by, for example, 4 
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clicking on the "Protein" tab that is shown illustratively in fine view pane 1 335 of 
Figure 1 3A. GUI 1 350 may, in such an implementation, be displayed in place of 
sequence line 1 329 in fine view pane 1 335. The height of exon bar 1 365 may 
correspond, as one of the examples noted above, to the frequency with which an 
exon, or partial exon, occurs in the alternative splice transcripts. In the present 
example, various bar heights may occur within each exon and between different 
exons. 

[01 55] In the illustrated implementation shown in Figure 1 3A, sequence line 1 329 in pane 
1 325 indicates the region of sequence that is displayed in fine view pane 1 335. Fine 
view pane 1 33 5 may include a region of sequence that is user selectable. That is, a 
user may move line 1329 by any of a number of known techniques, such as dragging 
it with a mouse, and thereby indicate the region of sequence that is to be displayed in 
pane 1 335. Also, the user may select the type of sequence viewed in pane 1 335 in 
some implementations. The type of sequence may include the genomic DNA 
sequence, primary RNA transcript, messenger RNA transcript, and/or translated 
protein sequence. The user may also select to view one or more of the alternative 
splice transcripts and/or full length reference sequence aligned together. 

[01 56] Each of the panes of GUI 1 300 in the illustrated implementation has what are 

referred by those in the related art as scroll bars. A user may interact with GUI 1 300 
by selecting a scroll bar and moving it in a desired direction to change what is 
displayed in the associated pane. For example, a user may select the vertical scroll bar 
associated with fine view pane 1 335 and move it in a desired direction. The displayed 
sequence displayed in pane 1 335 will change according to the direction of movement 
of the scroll bar as well as the position of sequence line 1 329 in intermediate view 
pane 1 325. 

[0157] 

Additionally, a scroll bar or other method of selection could be used for what may 
be referred to as "semantic zooming". This term as used herein refers to increasing or 
decreasing the levels of magnification and resolution in a display. With a change in 
magnification, objects may change appearance or shape as they change size. 
Moreover, when magnification of a displayed image is increased, additional 
information may be displayed relating to elements of the display. Conversely, when 
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the magnification of an image is decreased, less information may be displayed for 
individual elements of the display. For example, when alternative splice variants are 
displayed at low magnification, the displayed image may include general exon 
structure and alignments. As the magnification is increased, the sequence of the 
alternative splice variants may be displayed as well as annotation information. Thus, 
not only is the magnification of the information changed, the amount, content, and/or 
type of information also may be changed in relation to the change of magnification. 
For a review of semantic and other zooming technology, see, e.g., CounterPoint: 
Creating Jazzy Interactive Presentations, Good, L, Bederson, B.B., HCIL-2001-3, CS- 
TR-4225, UMIACS-TR-2001-14, March 2001; Jazz: An Extensible Zoomable User 
Interface Graphics Toolkit in Java, Bederson, B., Meyer, J. , Good, L. HCIL-2000-1 3, CS- 
TR-41 37, UMIACS-TR-2000-30, May 2000, In ACM UIST 2000, pp. 171-1 80; Jazz: An 
Extensible 2D+ Zooming Graphics Toolkit in Java Bederson, B., McAlister, B. HCIL-99- 
07, CS-TR-401 5, UMIACS-TR-99-24, May 1 999; Does Zooming Improve Image 
Browsing? Combs, T., T.A., and Bederson, B., HCIL-99-05, CS-TR-3995, UMIACS-TR- 
99-14, February 1999 In ACM Digital Library Conference, pp. 130-137; Graphical 
Multiscale Web Histories: A Study of PadPrints Hightower, R.R., Ring, LT., Helfman, 
J. I., Bederson, B.B., and Hollan, J.D. ACM Conference on Hypertext 1 999; Does 
Animation Help Users Build Mental Maps of Spatial Information, Bederson, B. and 
Boltman, A., CS-TR-3964, UMIACS-TR-98-73, September 1998, In IEEE Info Vis 99, 
pp. 28 35; A Zooming Web Browser, Bederson, B.B., Hollan, J.D. , Stewart, J., Rogers, 
D., Vick, D., Ring, L.T., Grose, E., Forsythe, C. Human Factors in Web Development, 
Eds. Ratner, Grose, and Forsythe, Lawrence Erlbaum Assoc., pp 255-266, 1998; 
implementing a Zooming User Interface: Experience Building Pad + + , Bederson, B., 
Meyer, J., Software: Practice and Experience, 28 (10), pp. 1 101-1 13 5, August 1998; 
When Two Hands Are Better Than One:Enhancing Collaboration Using Single Display 
Groupware, Stewart, J., Raybourn, E.M., Bederson, B.B., Druin, A., ACM CHI 98 
Summary, 1998; KidPad: A Design Collaboration Between Children, Technologists, and 
Educators, Druin, A., Stewart, J., Proft, D., Bederson, B.B., Hollan, J.D. , ACM CHI 97, pp 
463-470, 1997; A Multiscale Narrative: Gray Matters, Wardrip-Fruin, N., Meyer, J., 
PerlinJ., Bederson, B.B., Hollan, J. D.,ACM SIGGRAPH 97 Visual Proceedings, p 141, 
1 997; A Zooming Web Browser, Bederson, B.B., Hollan, J.D., Stewart, J., Rogers, D., 
Druin, A., and Vick, D. SPIE Multimedia Computing and Networking, Volume 2667, pp 
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260-271 , 1996; Local Tools: An Alternative to Tool Palettes, Bederson, B.B., Hollan, 
J.D., Druin, A., Stewart, J., Rogers, D., Proft, D., ACM UIST '96, pp 1 69-1 70, 1 996; 
Pad+ + : A Zoomable Graphical Sketchpad for Exploring Alternate Interface Physics, 
Bederson, B., Hollan, J., Perlin, K., Meyer, J., Bacon, D., and Furnas, G., Journal of 
Visual Languages and Computing, 7, 3-31, 1996, HTML, Postscript without pictures 
(74K), PDF without pictures (77K) 1995; Space-Scale Diagrams: Understanding 
Multiscale Interfaces, Furnas, G., Bederson, B., ACM SIGCHI '95; Advances in the 
Pad++ Zoomable Graphics Widget, Bederson, B., Hollan, J. USENIX Tcl/Tk*95 
Workshop; Pad + + : Advances in Multiscale Interfaces, Bederson, B.B., Stead, L., Hollan, 
J.D. ACM SIGCHI '94 (short paper), 1 994; Pad + + : A Zooming Graphical Interface for 
Exploring Alternate Interface Physics, Bederson, B.B., Hollan, J.D. , , ACM UIST '94, 
1 994; Pad - An Alternative Approach to the Computer Interface, Perlin, K., Fox, D., 
ACM SIGGRAPH '93; A Multiscale Approach to Interactive Display Organization, Perlin, 
K., Coordination Theory and Collaboration Technology Workshop, National Science 
Foundation, June 1991, each of which is hereby incorporated by reference herein in 
their entireties for all purposes. 

[01 58] 

Additional interactive features of GUI 1300 may include selecting elements such as 
an exon bar 1 303 by moving a cursor via mouse or keyboard and clicking the button 
on the mouse, or pressing the enter key on the keyboard, or other method commonly 
used for selecting elements. When a user selects an element or elements, portal 400 
may alter the display in the graphical user interface and/or present one or more 
additional graphical user interfaces, or windows. One such example of interactive 
features is presented in Figure 1 3B. GUI 1 350 shown in Figure 1 3B displays alternative 
splice variants in the context of what is referred to as the "central dogma" of 
molecular biology. The central dogma generally refers to the process of DNA 
producing transcripts (RNA) that are translated into protein. For example, a GUI may 
be used to display the alternative splice transcripts by level (i.e., DNA, RNA or protein) 
as indicated by GUI 1 3 50 that presents information at the protein level. Similar to 
Figure 1 3A, Figure 1 3B displays exon bars 1 303 and other related elements. 
Additionally, GUI 1 350 may display additional elements such as protein domain 1 360. 
As is well known to those of ordinary skill in the relevant art, proteins often include 
conserved regions referred to as domains, or modules, that have distinct evolutionary 
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origin and function. Information regarding the sequences, locations, homology, 
functions, two-dimensional or three-dimensional structure, and other aspects of 
protein domains or modules may, for example, be obtained in the manner described 
above from numerous remote databases 402 (for example, the Smart, Pfarn, and NCBI 
CDD web-based databases and similar databases that may be developed in the 
future). Additional aspects of data collection and characterization regarding protein 
domains and protein-protein interactions are described in U.S. Provisional Patent 
Application No. 60/385,626, filed June 4, 2002, titled "System, Method, and Product 
for Predicting Protein Interactions," which is hereby incorporated herein by reference 
in its entirety for all purposes. The elements displayed in GUI 1 350 may vary 
according to the level. For example, the protein level may display protein annotations 
in greater detail than the transcript level, while the transcript level may display greater 
detail with respect to probe set annotations. 

[01 59] Additional examples of visualizing alternative splice variants are provided in U.S. 

Provisional Patent Application Serial No. 60/394,574, titled "METHOD, SYSTEM, AND 
COMPUTER SOFTWARE FOR PROVIDING A GENOMIC WEB PORTAL", filed July 9, 2002, 
incorporated by reference above, and U.S. Provisional Patent Application Serial No. 
60/375,875, titled "VISUALIZATION SOFTWARE FOR DISPLAYING GENOMIC SEQUENCE 
AND ANNOTATIONS", filed April 25, 2002, incorporated by reference above. 

[01 60] As used herein, the term "graphical user interface" is intended to be broadly 
interpreted so as to include various ways of communicating information to, and 
obtaining information from, a user. For example, information may be sent to a user in 
an email as an alternative to, or in addition to, presenting the information on a 
computer screen employing graphical elements (such as shown illustratively in Figures 
1 3A and 1 3B). As is known by those of ordinary skill in the relevant art, the email may 
include graphics, or be designed to invoke graphics, similar to those that may be 
displayed in an interactive graphical user interface. 

[0161] 

One of many possible examples of the utility of these features includes a situation 
in which user 101 inputs a nucleotide sequence for which there is no corresponding 
existing probe set, as determined by correlator 830, described above. The sequence is 
translated by correlator 830 into a protein sequence by known methods (alternatively, 
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user 101 may have entered a protein sequence), and clustered using the HMM's for all, 
or any user-selected portion, of the available databases. In the present example, it is 
assumed that a number of positive family identifications are made, and all related 
annotation data is presented to the user via a GUI as well as being stored on the user's 
LIMS system. After compiling and reviewing the annotation data, the user may choose 
to order a probe set that corresponds to the nucleotide sequence by including the new 
probe set in an order for a custom probe array. 

[01 62] In yet another example, a user may specify a sequence, which may for example be 
a putative gene that does not correspond to any probe set. Correlator 830 correlates 
the user-specified sequence with one or more of the databases shown in Figure 10 (or 
other databases) included in database 518, and identifies possibly related sequences 
(which may be related by family, functional, or other criteria other than, or in addition 
to, sequence). User-service manager 522 identifies the probe sets associated with the 
related sequences and/or the associated ESTs, genes, and/or proteins. The identified 
probe sets, and optionally the array types in which they are represented, are provided 
to user 1 01 in an appropriate GUI and/or by other techniques such as email. Examples 
of probe-set annotations are provided in U.S. Provisional Patent Application, Serial No. 
60/306,033, incorporated by reference above. 

[01 63] Returning to the example of Figure 9 described above, correlator 830 formulates a 
query via database manager 512 to database 513 to obtain links to appropriate 
information located in local products database 514 and/or local genomic database 
518. With respect to some specific implementations, one or more links 91 6 to related 
products and/or genomic data may be obtained by following the appropriate links 
904 to probe-set ID's 91 2. In the present example, link 904N may link to probe-set 
91 2C, which is associated with links 91 6C to related product and/or genomic data. 
The information used to establish this association may be predetermined based on 
expert input and/or computer-implemented analysis (e.g., statistical and/or by an 
adaptive system such as a neural network) of the nature of inquiries by users. For 
example, it may be observed or anticipated (by humans or computers, as noted) that 
users conducting gene expression experiments resulting in the identification of 
certain genes may wish to use antibodies against the genes to conduct follow-on 
protein level experiments. The association between the genes and the appropriate 
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antibodies may be stored in an appropriate database, such as database 516. Links 
91 6C may thus include links to product or genomic data identifiers that identify links 
to data about the appropriate antibodies (for example, a link to product/genomic ID 
922A), to catalogues of antibodies generally (e.g., ID 922B), or to a probe array 
specifically designed for detecting alternatively spliced forms of the genes of interest 
(e.g., ID 922C). It is assumed for illustrative purposes that, in a particular aspect of 
this example, link 91 6C leads to ID 922C. Information about the availability of splice- 
variant probe arrays may be predetermined by the contents of links 926. For example, 
links 926D (associated with ID 922C, as shown) may be stored Internet and/or 
database-query URL's leading to vendor web pages, local products database 514, 
and/or local genomic database 518. Also, the content of links 926D may be 
dynamically determined by query of databases 514 or 51 8 or of remote data sources 
such as databases 402 or web pages 404. These and similar processes are 
represented by step 73 5 of Figure 7. 

[01 64] As will now be appreciated by those of ordinary skill in the art, numerous 

variations and alternative implementations of this illustrative arrangement of database 
513 are possible. For example, probe-set identification data may be linked to array 
identifiers (such as array ID 91 4), which may then be associated with links 916. As 
another of many possible examples, gene or EST accession numbers may be linked 
directly to product and/or genomic data ID 922 or, even more directly, to links 926. 
Implementations such as the illustrated one provide opportunities for making broad 
associations based on a more narrow inquiry by a user. For instance, a user may select 
only one probe-set identifier, but that identifier may be linked to multiple genes 
and/or ESTs, which may be linked to multiple products or genomic data. In another 
example, link 926D may include a link to local genomic database 51 8. Based on the 
probe-set identifiers, gene or EST accession numbers, sequence information, or other 
data provided by or deduced from user 101's inquiry, database 518 may be searched 
for associated data in accordance with known query and/or search techniques. 

[01 65] Returning now to Figure 7A and step 740 in particular, data returned in 

accordance with the query posed by correlator 830 is provided to either product data 
processor 842, genomic data processor 844, or both, as appropriate in view of the 
nature of the returned data. The functions of processors 842 and 844 are shown as 
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separated for convenience of illustration, but it need not be so. Processors 842 and 
844 apply any of a variety of known presentation or data transfer techniques to 
prepare graphical user interfaces, files for transfer, and other forms of data. This 
processed data is then provided to output manager 534 for transmission to client 
410. 

[01 66] In some implementations, user 1 01 may respond to the data thus transmitted by 
indicating a desire to purchase a product or receive further information. A request for 
further information may be processed in a manner similar to that described above and 
illustrated in Figure 7 A as decision element 745. If user 1 01 indicates a desire to 
purchase a product, the indicated product may be prepared for shipment or otherwise 
processed, and the user's account may be adjusted, in accordance with known 
techniques for conducting e-commerce. As one of many alternative implementations, 
user-service manager 522 may notify the product vendor of user 1 01 's order and the 
vendor may ship, or order the shipment of, the product. Manager 522 may then note, 
in one aspect of this implementation, that a fee should be collected from the vendor 
for the referral. 

[01 67] jn SQme implementations of portal 400, user 101 may provide to portal 400 (e.g., 
via client 41 0, Internet 499, and input manager 532) one or more gene or EST 
accession numbers or other gene or EST identifiers. Alternatively, or in addition, user 
101 may provide to portal 400 one or more probe-set identifiers. User 101 may 
obtain the gene, EST, and/or probe-set identifier from a public source, from notations 
user 1 01 has taken as a result of experiments with a probe array or otherwise, from a 
list of genes or ESTs having corresponding probes on a probe array, or from any other 
source or obtained in any other manner. Input manager 532 receives the one or more 
gene, EST, or probe-set identifiers and provides it or them to user-service manager 
522, which formulates a query to database manager 512. In accordance with known 
query techniques and formats, the query seeks information from local products 
database 514 of product information related to the gene, EST, and/or probe-set 
identifiers. For this purpose, local products database 514 may be indexed, or 
otherwise searchable, for products based or keyed on any one or more of gene, EST, 
and/or probe-set identifiers. Some implementations may include, according to known 
techniques, similarity matching of a gene, EST, or probe-set identifier if, for example, 
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all or part of a gene, EST, SIF (corresponding to the probe-set identifier) sequence is 
submitted. Also, a name-association function, in accordance with known techniques 
such as look-up tables, may be performed so that alternative names or forms of a 
gene, EST, or probe-set identifier may be found and used in the product data inquiry. 
In addition, in some implementations, manager 522 may initiate a remote data search 
of remote databases 402 and/or remote vendor web pages 404, in accordance with 
known Internet search techniques, to obtain product information from remote 
sources. These searches may be based, for example, on product categories or vendors 
associated in local products database 514 with products, categories, or vendors 
associated with the gene, EST, or probe-set identifier provided by user 101 . Manager 
522 may provide product data corresponding to the gene, EST, and/or probe-set 
identifier, obtained from local products database 514 and/or remote pages or 
databases 404 or 402, and provide this product data to user 1 01 via output manager 
534. For example, this product data may be included in web pages 524. In some of 
these implementations, portal 400 thus provides a system for providing product data, 
typically biological product data. The system includes input manager 532 that receives 
from user 101 one or more of a gene, EST, and/or probe-set identifier; user-service 
manager 522 that correlates the gene, EST, and/or probe-set identifier with one or 
more product data and that causes (e.g., via database manager 512) the product data 
to be obtained either locally from, e.g., database 514 or, in some implementations, 
remotely from, e.g., pages 404 or databases 402; and output manager 534 that 
provides the product data to user 1 01 . 

[01 68] Similarly, a method is provided for providing biological product data, including the 
steps of: receiving from user 101 any one or more of a gene, EST, and/or probe-set 
identifier; correlating the gene, EST, and/or probe-set identifier with one or more 
product data; causing the product data to be obtained either locally from, e.g., 
database 514 and/or remotely from, e.g., pages 404 or databases 402; and providing 
the product data to user 1 01 . 

[01 69] As j nc ji ca ted above, functional elements of portal 400 may be implemented in 
hardware, software, firmware, or any combination thereof. In the embodiment 
described above, it generally has been assumed for convenience that the functions of 
portal 400 are implemented in software. That is, the functional elements of the 
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illustrated embodiment comprise sets of software instructions that cause the 
described functions to be performed. These software instructions may be 
programmed in any programming language, such as Java, Perl, C+ + , another high- 
level programming language, low-level languages, and any combination thereof. The 
functional elements of portal 400 may therefore be referred to as carrying out "a set 
of genomic web portal instructions," and its functional elements may similarly be 
described as sets of genomic web portal instructions for execution by servers 5 1 0, 
520, and 530. 

[01 70] In some embodiments, a computer program product is described comprising a 

computer usable medium having control logic (computer software program, including 
program code) stored therein. The control logic, when executed by a processor, 
causes the processor to perform functions of portal 400 as described herein. In other 
embodiments, some such functions are implemented primarily in hardware using, for 
example, a hardware state machine. Implementation of the hardware state machine so 
as to perform the functions described herein will be apparent to those skilled in the 
relevant arts. 

[01 71] Aspects of probe selection and design and other features applicable to 

implementations of the present invention are described in greater detail in the 
following patent applications, all of which are hereby incorporated by reference herein 
in their entireties for all purposes: U.S. Patent Applications Serial Nos. 1 0/028,884, 
titled "Method and Computer software Product for Genomic Alignment and 
Assessment of the Transcriptome," filed December 21 , 2001 ; 10/027,682, titled 
Method and Computer Software Product for Defining Multiple Probe Selection 
Regions," filed December 2 1 , 2001 ; 1 0/028,41 6, titled "Method and Computer 
Software Product for Predicting Polyadenylation Sites," filed December 21 , 2001 ; and 
1 0/006,1 74, titled "Methods and Computer for Designing Nucleic Acid Probe Arrays," 
filed December 4, 2001. 

[01 72] 

Having described various embodiments and implementations, it should be 
apparent to those skilled in the relevant art that the foregoing is illustrative only and 
not limiting, having been presented by way of example only. Many other schemes for 
distributing functions among the various functional elements of the illustrated 
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embodiment are possible. The functions of any element may be carried out in various 
ways and by various elements in alternative embodiments. For example, some or all of 
the functions described as being carried out by determiner 820 could be carried out 
by correlator 830, or these functions could otherwise be distributed among other 
functional elements. Also, the functions of several elements may, in alternative 
embodiments, be carried out by fewer, or a single, element. For example, the 
functions of determiner 820 and correlator 830 could be carried out by a single 
element in other implementations. Similarly, in some embodiments, any functional 
element may perform fewer, or different, operations than those described with respect 
to the illustrated embodiment. Also, functional elements shown as distinct for 
purposes of illustration may be incorporated within other functional elements in a 
particular implementation. For example, the division of functions between an 
application server and a network server of the genome portal is illustrative only. The 
functions performed by the two servers could be performed by a single server or other 
computing platform, distributed over more than two computer platforms, or other 
otherwise distributed in accordance with various known computing techniques. 

[0173] 

Also, the sequencing of functions or portions of functions generally may be 
altered. Certain functional elements, files, data structures, and so on, may be 
described in the illustrated embodiments as located in system memory of a particular 
computer. In other embodiments, however, they may be located on, or distributed 
across, computer systems or other platforms that are co-located and/or remote from 
each other. For example, any one or more of data files or data structures described as 
co-located on and "local" to a server or other computer may be located in a computer 
system or systems remote from the server. In addition, it will be understood by those 
skilled in the relevant art that control and data flows between and among functional 
elements and various data structures may vary in many ways from the control and 
data flows described above or in documents incorporated by reference herein. More 
particularly, intermediary functional elements may direct control or data flows, and 
the functions of various elements may be combined, divided, or otherwise rearranged 
to allow parallel or distributed processing or for other reasons. Also, intermediate 
data structures or files may be used and various described data structures or files may 
be combined or otherwise arranged. Numerous other embodiments, and modifications 
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thereof, are contemplated as falling within the scope of the present invention as 
defined by appended claims and equivalents thereto. 

[01 74] What is claimed is: 
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